Dynamics CRM2016 Web API之查询单个属性字段的值

时间:2022-02-19 10:41:16

     之前已有文章介绍过通过web api来更新单个属性字段的值,本篇要讲的是查询,查询其实很简单但其中有个注意点,这就是本篇文章的目的。

    主要的区别在于js代码返回的结果的处理上,下面这段代码乍看之下没问题,其实是错的,request的url的url是没问题的,错在返回结果的处理上

 var req = new XMLHttpRequest()
req.open("get", Xrm.Page.context.getClientUrl() + "/api/data/v8.0/" + entityName
+ "(" + id.replace('{', '').replace('}', '') + ")/" + property, isasync);
req.setRequestHeader("Accept", "application/json");
req.setRequestHeader("Content-Type", "application/json; charset=utf-8");
req.setRequestHeader("OData-MaxVersion", "4.0");
req.setRequestHeader("OData-Version", "4.0");
req.onreadystatechange = function () {
if (this.readyState == 4) {
if (this.status == 200) {
successCallback(JSON.parse(this.responseText).value);
}
else {
errorCallback(JSON.parse(this.responseText).error.message);
}
}
};
req.send();


    咱们来看两张不同结果的返回图,第一张图查询的字段是有值的,返回的status是200,responsetext也是有值的。

Dynamics CRM2016 Web API之查询单个属性字段的值

    再来看第二张字段值为空的时候,返回的status是204,内容为空,所以这块是有区别的,要特别注意下。

Dynamics CRM2016 Web API之查询单个属性字段的值

    在server端的C#代码中HttpWebResponse返回值不会有这个问题。