2

私は Mscrm.CrmDialog を使用して、MS Dynamics CRM 2013 で Web リソースを含む新しいダイアログを表示します。この方法の利点は、このダイアログが Firefox や Chrome などでも機能することです。

とにかく、パラメーターを webresource に渡す必要があります。window.showModalDialog ではこれは問題ありませんでしたが、Mscrm.CrmDialog を使用すると、パラメーターを渡す方法が見つかりませんでした。コンストラクターにはパラメーター 'customWindowParameters' がありますが、Web リソースからこれらのパラメーターにアクセスするにはどうすればよいですか?

4

1 に答える 1

5

次のように、ダイアログ (Mscrm.CrmDialog) を呼び出す場所からスクリプトでグローバル変数を宣言します。

var variable1 = 5;
var object1 = { Id: 1, name: "SWA" };

function ribbon_OpenDialog() {
    var clientUrl = Xrm.Page.context.getClientUrl();
    var url = clientUrl + "/WebResources/new_myWebResource.html";
    //CRM 2015 SP 1
    var dialogwindow = new parent.Mscrm.CrmDialog(parent.Mscrm.CrmUri.create(url), this, 450, 175);
    //For CRM less than CRM 2015 SP 1
    //var dialogwindow = new Mscrm.CrmDialog(Mscrm.CrmUri.create(url), this, 450, 175);
    dialogwindow.show();
}

上記のグローバルに宣言された変数はwindow.getDialogArguments()、次のサンプル html webresource のように、webresource でアクセスできます。

<html>
<head>
    <title></title>
    <script src="ClientGlobalContext.js.aspx" type="text/javascript"></script>
    <script type="text/javascript">
        var dialog;
        if (window.getDialogArguments() != null) {
            dialog = window.getDialogArguments();
        }
        var v1 = dialog.variable1;
        var o1 = dialog.object1;

        function doSomthing() {
            alert("variable1= " + v1 + "\n object1.Id=" + o1.Id + "\n object1.name=" + o1.name);
        }
    </script>
    <style type="text/css">
        .dvrow {
            clear: both;
            margin: 2px auto 0 auto;
            padding: 10px 0 10px 0;
            width: 96%;
        }
        .headerTitle {
            font-family: Segoe UI Light, Segoe UI, Tahoma, Arial;
            font-size: 27px;
            font-weight: lighter;
        }
    </style>
</head>
<body>
    <form id="formPopup">
        <div id="spinner">
        </div>
        <div class="dvrow">
            <div class="headerTitle">
               Test dialog Popup
            </div>
            <div class="row">
                <button title="Run" id="btnRun" onclick="doSomthing();" type="button">Run</button>
            </div>
        </div>
    </form>
</body>
</html>

[実行] ボタンをクリックすると、次の結果が得られます。
ここに画像の説明を入力

于 2015-06-25T07:19:39.760 に答える