• Dynamics 365站点地图中添加动态链接


    我是微软Dynamics 365 & Power Platform方面的工程师/顾问罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面的微软最有价值专家(Microsoft MVP),欢迎关注我的微信公众号 MSFTDynamics365erLuoYong ,回复424或者20201010可方便获取本文,同时可以在第一间得到我发布的最新博文信息,follow me!

    有时候我们需要在站点地图中添加链接,如果是静态链接,比较好办,比如链接到某个公共网址裁判文书网,网址是 https://wenshu.court.gov.cn/ ,这么设置下就可以

     但是如果这个网址是动态的,比如一个Canvas App 的URL,不同的环境(environment)是不同的,那如何设置呢?如果设置为某个环境的URL,那么新环境就需要手动更改,每次更改容易忘记,也不方便。这时候可以考虑将这个导航项目设置为某个HTML 类型的Web资源,类似如下。

     这种做法可以做到在当前页面打开,也就是在导航项目的右边打开,如果需要在新窗口中打开呢?那就需要在代码中使用类似 window.open 代码。这个还有个问题,那么右边的显示区域是空白的,还好颜色是主题的背景色,不算太违和。你会发现,如果导航项目设置的是绝对URL,那么点击这个导航项目会直接将绝对URL在新Tab中打开,导航项目不会变化,比如之前打开的是Case实体,还是保留在Case实体。如何也做到类似的效果呢?没有特别好的办法,只有在代码中加上类似 window.history.back();  的代码就做出来的效果就非常像了。

    还有一个问题,我这做的动态链接其实都存放在一个实体中,我需要的只是一个名称name就可以去获取了,当设置导航项目是Web资源时候可以传递参数过来吗?答案是可以的。界面上设置似乎效果不好,可以直接编辑站点地图的URL,我这里举个例子。值得注意的是要用 data 这个query string key来传递值,传递的键值对要用JavaScript encodeURIComponent 函数编码下,比如 = 需要转换成 %3D 。

                <SubArea Id="NewSubArea_1ac8c778" ResourceId="SitemapDesigner.NewSubArea" Url="$webresource:ly_/page/common/dynamicredirectpage.html?data=name%3DConiguration_Name" Client="All,Outlook,OutlookLaptopClient,OutlookWorkstationClient,Web" AvailableOffline="true" PassParams="false" Sku="All,OnPremise,Live,SPLA">
                  <Titles>
                    <Title LCID="1033" Title="Dynamics URL Demo" />
                  </Titles>
                </SubArea>

    下面再给这个HTML Web资源的代码示例如下:

    <!DOCTYPE html>
    
    <html lang="en" xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <meta http-equiv="X-UA-Compatible" content="IE=edge" charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Lenovo</title>
        <script src="../../../ClientGlobalContext.js.aspx" type="text/javascript"></script>
    </head>
    <body onload="onLoad()">
        <script type="text/javascript">
            function onLoad() {
                window.history.back();
                var name = "YouKey";
                var queryStrArray = new Array();
                var vals = new Array();
                if (location.search !== "") {
                    queryStrArray = location.search.substr(1).split("&");
                    for (var i in queryStrArray) {
                        queryStrArray[i] = queryStrArray[i].replace(/+/g, " ").split("=");
                    }
                    for (var i in queryStrArray) {
                        if (queryStrArray[i][0].toLowerCase() === "data") {
                            vals = decodeURIComponent(queryStrArray[i][1]).split("&");
                            for (var i in vals) {
                                vals[i] = vals[i].replace(/+/g, " ").split("=");
                                if (vals[i][0].toLowerCase() === "name") {
                                    name = vals[i][1];
                                }
                            }
                            break;
                        }
                    }
                }
                if (typeof GetGlobalContext !== "undefined") {
                    var clientUrl = GetGlobalContext().getClientUrl() + "/api/data/v9.1/";
                    var req = new XMLHttpRequest();
                    req.open("GET", encodeURI(clientUrl + "ly_configs?$select=ly_url&$filter=ly_name eq '" + name + "' and statecode eq 0&$top=1"), 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.onreadystatechange = function () {
                        if (this.readyState === 4 /* complete */) {
                            req.onreadystatechange = null;
                            if (this.status === 200) {
                                var responseJson = JSON.parse(this.responseText);
                                if (responseJson.value.length >= 1) {
                                    window.open(responseJson.value[0].ly_url);
                                }
                            }
                            else {
                                throw new Error("Query data error:" + JSON.parse(this.responseText));
                            }
                        }
                    };
                    req.send();
                } else {
                    throw new Error("Reference to ClientGlobalContext.js.aspx error.");
                }
            }
        </script>
    </body>
    </html>
  • 相关阅读:
    NOIP2017 时间复杂度 大模拟
    【Python】CV2的一些基本操作
    【Python】类、对象、self
    【Ubuntu18.04】清空回收站
    小飞机可以解决git clone没有返回的问题吗?
    sqlserver2005 远程服务器数据 完全拷贝 到本地数据库
    Microsoft Visual Studio 2005 多线程时 解决不是该线程创建的来访问
    MS SqL2000 数据库置疑状态的解决方法[转]
    vue 函数配置项watch以及函数 $watch 源码分享
    Vue生命周期之beforeCreate vue 生命周期详解
  • 原文地址:https://www.cnblogs.com/luoyong0201/p/Dynamics_365_SiteMap_Add_Dynamic_URL.html
Copyright © 2020-2023  润新知