我使用以下代码将 odata 服务绑定(bind)到 sapui5 表
我无法将数据从 oData 服务获取到 SAPui5 表,odata 存储在单独的 vpn 客户端中。我正在使用反向代理服务器来检索数据
控制台中的错误显示在下面的链接中
代码:
//Creating the instance of oData model
var oModel = new sap.ui.model.odata.v2.ODataModel("http://admin-think:88/sap/...",{useBatch : true});
sap.ui.getCore().setModel(oModel,"model1");
console.log(oModel);
// Create instance of table
var oTable = new sap.ui.table.Table({
visibleRowCount : 6,
selectionMode: sap.ui.table.SelectionMode.Single,
navigationMode: sap.ui.table.NavigationMode.scrollbar,
selectionBehavior: sap.ui.table.SelectionBehavior.RowOnly
});
// First column "Application"
oTable.addColumn(new sap.ui.table.Column({
label : new sap.ui.commons.Label({
text : "APPLICATION",
textAlign : "Center",
}),
template : new sap.ui.commons.TextView({
textAlign:"Center"}).bindProperty("text","model1>Applno"),
}));
// Bind model to table control
oTable.bindRows("model1>/");
最佳答案
您的服务端点在这一行中可能不正确: var oModel = new sap.ui.model.odata.v2.ODataModel("http://admin- think:88/sap/... “,{useBatch:true});
。
在您发送的错误输出中,您可以看到应用程序正在尝试访问 URL http://.../ZTEST1_SRV/CoreOpenAppSet()/$metadata
。这会导致 404 状态,这意味着该服务在该 URL 上不可用。应用程序下载元数据的正确 URL 可能应该是 http://.../ZTEST1_SRV/$metadata
。
要解决此问题,您应该删除传递给 ODataModel 构造函数的变量的 CoreOpenAppSet()
部分。相反,您应该使用 ODataModel 的 callFunction
来调用此“函数导入”,即:oModel.callFunction()
。
当函数导入的调用完成并且返回的 Promise 得到解析时,您可以使用 setBindingContext
将调用结果绑定(bind)到您的 UI:
var oPromise = oModel.callFunction("/CoreOpenAppSet");
oPromise.contextCreated().then(function(oContext) {
oView.setBindingContext(oContext);
});
此外,最好在 list 中指定模型和端点,以便将它们与代码分开。您可以在这里了解更多信息:https://sapui5.netweaver.ondemand.com/docs/guide/8f93bf2b2b13402e9f035128ce8b495f.html
关于javascript - 如何将odata服务绑定(bind)到SAPUI5表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37990243/