我在CRM Online 2013自定义实体中的每个表单中都有一个保存在Notes中的图像。我使用以下代码查询图像并将其显示在窗体上的Web资源的图像标记中。出于调试目的,我通过一个按钮调用以下代码,但是我想要这个查询Notes的过程,并在表单加载时将web资源中的图像显示为自动。这是我的代码:
<html><head><meta charset="utf-8"></head>
<body>
<img id="image" src="nothing.jpg" style="width: 25%; height: auto;" />
<script type="text/javascript">
$(windows).load(function()
{
var recordId = window.parent.Xrm.Page.data.entity.getId();
var serverUrl = Xrm.Page.context.getServerUrl().toString();
var ODATA_ENDPOINT = "XRMServices/2011/OrganizationData.svc";
var objAnnotation = new Object();
ODataPath= serverUrl+ODATA_ENDPOINT;
var temp= "/AnnotationSet?$select=DocumentBody,FileName,MimeType,ObjectId&$filter=ObjectId/Id eq guid'" + recordId + "'";
var result =serverUrl + ODATA_ENDPOINT + temp;
var retrieveRecordsReq = new XMLHttpRequest();
retrieveRecordsReq.open('GET', ODataPath + temp, false);
retrieveRecordsReq.setRequestHeader("Accept", "application/json");
retrieveRecordsReq.setRequestHeader("Content-Type", "application/json; charset=utf-8");
retrieveRecordsReq.onreadystatechange = function ()
{
if (this.readyState == 4 /* complete */)
{
if (this.status == 200)
{
this.onreadystatechange = null; //avoids memory leaks
var data = JSON.parse(this.responseText, SDK.REST._dateReviver);
if (data && data.d && data.d.results)
{
SuccessFunc(JSON.parse(this.responseText, SDK.REST._dateReviver).d.results);
}
}
else
{
alert(SDK.REST._errorHandler(this));
}
}
};
var x = new XMLHttpRequest();
x.open("GET", result, true);
x.onreadystatechange = function ()
{
if (x.readyState == 4 && x.status == 200)
{
var doc = x.responseXML;
var title = doc.getElementsByTagName("feed")[0].getElementsByTagName("entry")[0].getElementsByTagName("content")[0].getElementsByTagName("m:properties")[0].getElementsByTagName("d:DocumentBody")[0].textContent;
document.getElementById('image').src ="data:image/png;base64,"+title;
}
};
x.send(null);
});
</script>
</body></html>
我已经删除了按钮标签..现在我希望这个查询发生在页面Load上,但是当我刷新表单时没有任何反应。在我看来,函数在注释加载之前加载。有没有办法让它等待并加载最后一个?
答案 0 :(得分:1)
如果你想等待父窗口加载,我认为$(windows).load(myFunction);
应该可以解决问题。
也许$ is undefined
因为您没有将jQuery添加到您的webressource。
还有一些小错误和没有吸引力的东西:
第一:
您将收到错误的服务器URL。
如果要访问Web资源中的Xrm对象,则必须始终使用window.parent.Xrm
或将其放入变量var Xrm = window.parent.Xrm;
例如:
var Xrm = window.parent.Xrm;
var recordId = Xrm.Page.data.entity.getId();
var serverUrl = Xrm.Page.context.getServerUrl().toString();
第二:
未声明ODataPath
变量。请改用var ODataPath= serverUrl+ODATA_ENDPOINT;
。顺便说一下,ODataPath
的值与OData无关。它更像是动态CRM的REST端点。
我的脚本看起来像这样:
var Xrm, recordId, serverUrl, restEndpointUrl, odataQuery, fullRequestUrl, xmlRequest;
Xrm = window.parent.Xrm;
recordId = Xrm.Page.data.entity.getId();
serverUrl = Xrm.Page.context.getServerUrl().toString();
restEndpointUrl = serverUrl + "/XRMServices/2011/OrganizationData.svc";
^ I think a '/' was missing there
odataQuery = "/AnnotationSet?$select=DocumentBody,FileName,MimeType,ObjectId&$filter=ObjectId/Id eq guid'" + recordId + "'";
fullRequestUrl = restEndpointUrl + odataQuery;
我也不明白你为什么要使用第二个HttpRequest。
所有这些代码都未经过测试。