我正在尝试使用addPreSearch
函数将自定义过滤器添加到查找字段,但是在显示查找结果之前,该函数似乎无法完全执行。此代码看起来像这样:
function onFieldChange(executionContext) {
var formContext = executionContext.getFormContext();
formContext.getControl("test_code").removePreSearch(testFunctionFilter);
formContext.getControl("test_code").addPreSearch(testFunctionFilter);
}
function testFunctionFilter(executionContext) {
var formContext = executionContext.getFormContext();
var record1 = formContext.getAttribute("test_record1_link").getValue(); //get linked record
var record1FullId, record1Id, stringRecordId, idLength, record1Guid = "0";
if (record1 != null) {
record1Id = record1[0].id;
record1Id = record1FullId.slice(1, -1);
stringRecordId = record1FullId.toString();
idLength = stringRecordId.length;
//Guid when retrieved from tablet does not have parenthesis on each end
if (idLength == 36) {
record1Guid = record1FullId;
} else {
record1Guid = recordId;
}
}
var fieldValue;
Xrm.WebApi.retrieveRecord("test_record1", record1Guid, "?$select=test_field1")
.then(function(result1) {
fieldValue = result1.test_field;
var options = generateOptions(executionContext, fieldValue); //creates option string using retrieved fieldValue
Xrm.WebApi.retrieveMultipleRecords("test_record2", options)
.then(function(result) {
var codes = getCodes(result2, fieldValue);
filter = generateFilter(codes, record1Guid); //creates custom filter using provided parameters
console.log(filter); //displays filter correctly
formContext.getControl("test_codelookup").addCustomFilter(filter, "test_coderecord"); //not working?
});
});
}
使用上面未定义定义的函数正确生成了过滤器。那不是问题。我尝试创建一个单独的测试函数,在其中我对上面的函数生成的一个过滤器进行了硬编码,并且查找显示了正确的结果。 testFunctionFilter
应该在显示查询结果之前运行完毕,对吗?因为在显示查询结果之后,筛选器已记录到控制台。嵌套的异步Xrm.WebApi
调用是否会导致此问题?我不太确定这是怎么回事。请告知。
答案 0 :(得分:0)
你是对的。 Xrm.WebApi
调用始终是异步,在使用addCustomFilter
添加动态过滤器的情况下,这是不可用的。
您必须使用XMLHttpRequest
并通过将第三个参数设置为false
来使该调用成为同步,
var req = new XMLHttpRequest();
req.open("GET", Xrm.Utility.getGlobalContext().getClientUrl() +
"/api/data/v9.0/test_record1?$select=test_field1", false);
答案 1 :(得分:0)
为了解决异步延迟问题,我认为您将不得不重新组织代码:
test_field1
并将结果缓存在参数中test_field1
并更新相同的参数(来自 onload ) li>