使用 javascript 获取属性名称在 dynamics CRM 中实体的主要形式
Get attribute names are in the main form of entity in dynamics CRM using javascript
我想使用 javascript.And 从 systemform 实体中获取属性的主要形式的逻辑名称,还想将这些名称保存在数组或列表中。
请建议我正确的查询以及如何从响应中获取每个属性的名称。
代码:
var serverUrl;
serverUrl = location.protocol + "//" + location.host;
function getformfields() {
debugger;
var oDataUri = "systemforms?$select=formxml&$filter=name eq 'account'";
var data = getODataRecords(oDataUri);
if(data!=null&&data!="")
{
//how to get field name from response
}
}
function getODataRecords(ODataUrl) {
debugger;
var data;
var Query = ODataUrl;
var req = new XMLHttpRequest();
req.open("GET", serverUrl + "/api/data/v8.0/" + Query, false);
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.setRequestHeader("Prefer", "odata.include-annotations=OData.Community.Display.V1.FormattedValue");
req.onreadystatechange = function () {
if (this.readyState == 4 /* complete */) {
req.onreadystatechange = null;
if (this.status == 200) {
data = JSON.parse(this.response);
}
else {
var error = JSON.parse(this.response).error;
alert(error.message);
}
}
};
req.send();
return data;
}
只是解析结果的问题formxml
属性。
唯一需要注意的是,如果多次添加某个属性,控件的 ID 会附加一个数字后缀,例如name1
、name2
等。datafieldname
属性指向控件引用的属性。
var data = getODataRecords(oDataUri);
if (data && data.value && data.value[0] && data.value[0].formxml) {
var xml = jQuery(data.value[0].formxml);
var controls = xml.find('control');
jQuery.each(controls, function(index, control) {
console.log(jQuery(control).attr('datafieldname'));
});
}
我想使用 javascript.And 从 systemform 实体中获取属性的主要形式的逻辑名称,还想将这些名称保存在数组或列表中。
请建议我正确的查询以及如何从响应中获取每个属性的名称。
代码:
var serverUrl;
serverUrl = location.protocol + "//" + location.host;
function getformfields() {
debugger;
var oDataUri = "systemforms?$select=formxml&$filter=name eq 'account'";
var data = getODataRecords(oDataUri);
if(data!=null&&data!="")
{
//how to get field name from response
}
}
function getODataRecords(ODataUrl) {
debugger;
var data;
var Query = ODataUrl;
var req = new XMLHttpRequest();
req.open("GET", serverUrl + "/api/data/v8.0/" + Query, false);
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.setRequestHeader("Prefer", "odata.include-annotations=OData.Community.Display.V1.FormattedValue");
req.onreadystatechange = function () {
if (this.readyState == 4 /* complete */) {
req.onreadystatechange = null;
if (this.status == 200) {
data = JSON.parse(this.response);
}
else {
var error = JSON.parse(this.response).error;
alert(error.message);
}
}
};
req.send();
return data;
}
只是解析结果的问题formxml
属性。
唯一需要注意的是,如果多次添加某个属性,控件的 ID 会附加一个数字后缀,例如name1
、name2
等。datafieldname
属性指向控件引用的属性。
var data = getODataRecords(oDataUri);
if (data && data.value && data.value[0] && data.value[0].formxml) {
var xml = jQuery(data.value[0].formxml);
var controls = xml.find('control');
jQuery.each(controls, function(index, control) {
console.log(jQuery(control).attr('datafieldname'));
});
}