在CRM表单中加载最后一个JavaScript事件

时间:2014-08-05 13:02:53

标签: javascript jquery dynamics-crm-2011 dynamics-crm dynamics-crm-online

我在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上,但是当我刷新表单时没有任何反应。在我看来,函数在注释加载之前加载。有没有办法让它等待并加载最后一个?

1 个答案:

答案 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。

所有这些代码都未经过测试。