微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SAP UI5 OData 请求的自定义 HTTP header 设置方法

代码如下:

oModel.setHeaders({"myHeader1" : "value1", "myHeader2" : "value2"});

我们可以先通过如下代码,拿到一个 OData Service url 对应的 OData Model 实例:

// "ODataModel" required from module "sap/ui/model/odata/v2/ODataModel"
var oModel = new ODataModel("http://myserver/MyService.svc/?myParam=value&myParam2=value");

添加自定义标头时,如果未在标头映射中再次指定,所有以前的自定义标头都将被删除。 有些header是私有的,也就是OData模型内部设置的,不能设置:

  • “accept”
  • “accept-language”
  • “maxdataserviceversion”
  • “dataserviceversion”
  • “x-csrf-token”

OData 模型的绑定路径语法与相对于 OData 中用于访问特定实体或实体集的服务 URL 的 URL 路径相匹配。

可以根据服务元数据中定义的 OData 服务结构访问 OData 模型提供的数据。 URL 参数(例如过滤器)不能添加到绑定路径中。 绑定路径可以是绝对的或相对的。 绝对绑定路径会立即解析。 相对路径只有在能够自动转换为绝对绑定路径的情况下才能被解析。

例如,如果属性绑定到相对路径,然后父控件绑定到绝对路径,则可以将相对属性路径解析为绝对路径

ODataModel 中的以下绑定示例取自 northwind 演示服务。

绝对绑定路径(以斜杠 (‘/’) 开头):

"/Customers"
"/Customers('ALFKI')/Address"

可以使用上下文解析的相对绑定路径(例如“/Customer(‘ALFKI’)”):

"CompanyName"
"Address"
"Orders"

解析成的绝对路径

"/Customer('ALFKI')/CompanyName"
"/Customer('ALFKI')/Address"
"/Customer('ALFKI')/Orders"

导航属性(navigation properties),用于标识单个实体或实体集合:

"/Customers('ALFKI')/Orders"
"/Products(1)/supplier"

从 OData 服务请求的数据缓存在 OData 模型中。

它可以通过 getproperty() 方法访问,该方法返回实体对象或值。 此方法不从后端请求数据,因此您只能访问已请求和缓存的实体:

oModel.getProperty("/Customer('ALFKI')/Address");

下列代码返回 undefined:

只能使用此方法访问单个实体和属性。 要访问实体集,可以通过列表绑定获取所有读取实体的绑定上下文。 此方法返回的值是模型中数据的副本,而不是 JSONModel 中的引用。

原文地址:https://cloud.tencent.com/developer/article/2133821

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐