使用OData模型在间隔时间内更改表的单元格

我有此代码,我需要我的表格显示前10名患者,并在10秒后显示下10名患者,而无需触摸任何按钮(自动)。

我正在寻找类似于此的内容:https://embed.plnkr.co/ioh85m5OtPmcvPHyl3Bg/

但使用OData模型(在我的视图和控制器上指定)。

这是我的观点:

<Table id="tablaPacientes" items="{/EspCoSet}">
  <columns>
    <!-- ... -->
  </columns>
  <ColumnListItem>
    <ObjectIdentifier title="{Bett}" />
    <!-- ... -->
  </ColumnListItem>
</Table>

这是我的控制器:

onInit: function () {
  var oModel = this.getOwnerComponent().getModel("zctv");
  this.getView().setModel(oModel);
},

onBeforeRendering: function () { // method to get the local IP because I need it for the OData
  var ipAddress;
  var RTCPeerConnection = window.webkitRTCPeerConnection || window.mozRTCPeerConnection;
  var self = this;

  function grepSDP (sdp) {
    var ip = /(192.168.(0|d{0,3}).(0|d{0,3}))/i;
    sdp.split('
').forEach(function (line) {
      if (line.match(ip)) {
        ipAddress = line.match(ip)[0];
        self.setIp(ipAddress);
      }
    });
  }

  if (RTCPeerConnection) {
    (function () {
      var rtc = new RTCPeerConnection({
        iceServers: []
      });
      rtc.createDataChannel('', {
        reliable: false
      });
      rtc.onicecandidate = function (evt) {
        if (evt.candidate) {
          grepSDP(evt.candidate.candidate);
        }
      };
      rtc.createOffer(function (offerDesc) {
        rtc.setLocalDescription(offerDesc);
      }, function (e) {
        console.log("Failed to get Ip address");
      });
    })();
  }
},

setIp: function (ip) {
  this.getView().byId("planta").bindElement({
    path: "/CenTVSet('" + ip + "')"
  });
  var oModel = this.getView().getModel();
  var that = this;
  oModel.read("/CenTVSet('" + ip + "')", {
    success: function (oData, oRes) {
      var einri = oData.Einri;
      var orgpf = oData.Orgpf;
      var oTable = that.getView().byId("tablaPacientes");
      var oBinding = oTable.getBinding("items");
      var aFilters = [];
      var filterO = new Filter("Orgna", sap.ui.model.FilterOperator.EQ, orgpf);
      aFilters.push(filterO);
      var filterE = new Filter("Einri", sap.ui.model.FilterOperator.EQ, einri);
      aFilters.push(filterE);
      oBinding.filter(aFilters);
    }
  });
}

我搜索了一些函数,如IntervalTrigger,但我真的不知道如何在此示例中使用它。


解决方案

这里有一个小的示例:https://embed.plnkr.co/4zIAH7q2E0lngbyX

startList: function(listBase, $skip, $top, restInfo) {
  let startIndex = $skip;
  let length = $top;
  let totalSize;
  (function repeat(that) {
    const bindingInfo = Object.assign({ startIndex, length }, restInfo);
    listBase.bindItems(bindingInfo);
    listBase.data("repeater", event => {
      totalSize = event.getParameter("total"); // $count value
      startIndex += $top;
      startIndex = startIndex < totalSize ? startIndex : 0;
      setTimeout(() => repeat(that), 2000);
    }).attachEventOnce("updateFinished", listBase.data("repeater"), that);
  })(this);
},

stopList: function(listBase) {
  listBase.detachEvent("updateFinished", listBase.data("repeater"), this);
},

该示例使用了OData V4 Trippin服务,但同样适用于任何与OData V2兼容的服务(使用mockserver和real V2服务进行了测试)。我在控制器中为OData V2案例添加了注释。

示例使用列表绑定信息中的startIndexlength,转换为实体请求URL的$skip$top系统查询。因此,请确保您的OData服务预期支持$skip$top。即将这些系统查询附加到请求URL(例如https://<host>/<service>/<EntitySet>?$skip=3&$top=3),应返回正确的实体集like this。

如我所述,列表绑定信息的其他选项可以在UI5文档中找到here。

JavaScript部件

该间隔使用LIFE(立即调用的函数表达式)与setTimeout(而不是setInterval)组合来实现。

setInterval有以下缺点:

  • 不会立即调用回调。您必须先等待10秒才能触发第一个回调。
  • 不等待数据响应到达。这可能会导致跳过批处理或显示批处理的时间太短,因为无论服务器响应如何,延迟都会继续。

setTimeout改为在应该请求下一批时提供更好的控件。

相关文章