关注本人微信和易信公众号: 微软动态CRM专家罗勇 ,回复228或者20161026可方便获取本文,同时可以在第一间得到我发布的最新的博文信息,follow me!我的网站是 www.luoyong.me 。

首先我们来看看通过getQueryStringParameters来获取参数的值。点击子网格的加号进行增加记录的时候,会发现URL中是类似这样的,https://demo.luoyong.me/main.aspx?etc=10008&extraqs=%3f_CreateFromId%3d%257bB707DE1B-CF99-E611-8161-000D3A80C8B8%257d%26_CreateFromType%3d10007%26etc%3d10008&histKey=881427917&newWindow=true&pagetype=entityrecord#908569294 
这里就可以通过getQueryStringParameters来获取参数_CreateFromId的值,这个值也就是自网格对应父记录的ID。代码如下:
Xrm.Utility.alertDialog("父记录ID=" + Xrm.Page.context.getQueryStringParameters()._CreateFromId);
 
我们知道每个调用的函数都可以做如下的设置:
 
如果选中了 将执行上下文作为第一个参数传递 ,那么执行函数的第一个参数的值将会传递它过来。
将传递给函数的以都好分隔的参数列表,我们可以以逗号分隔传递给执行函数参数,我这里第一个是传递数字参数10,第二个是传递字符串类型的参数,第三个也是字符串类型的参数,但是我希望在代码中可以转换为日期,所以我使用了类似 2016-01-01 00:00:00 的格式字符串来传递。然后执行的代码可能就类似如下了:
function OnLoad(eContext, numberPara, stringPara, datePara) {
Xrm.Utility.alertDialog("传递过来的数字参数numberPara值是" + numberPara + ",类型是" + typeof (numberPara) + ";\n传递过来的字符参数stringPara值是" + stringPara + ",类型是" + typeof (stringPara) + ";\n传递过来的日期参数datePara值是:" + new Date(datePara).toLocaleString());
}

当然啦,插入的Web资源还可以传递参数,我这里设置如下:

可以看到既选择了 将记录对象类型代码和唯一标识符作为参数传递 ,还在 自定义参数(数据) 部分定义了一些自定义参数传递过去,我可以使用如下代码获取到值:
var queryStrings = GetGlobalContext().getQueryStringParameters();
var alertStr = [];
for (var prop in queryStrings) {
if (prop.toLocaleLowerCase() != "data") {
alertStr.push("传递的参数名是" + prop + ";参数值是:" + queryStrings[prop]);
}
else {
var dataParaArray = queryStrings[prop].toString().split('&');
for (var i = 0; i < dataParaArray.length; i++) {
alertStr.push("传递的参数名是" + dataParaArray[i].split('=')[0] + ";参数值是:" + dataParaArray[i].split('=')[1]);
}
}
}
Xrm.Utility.alertDialog(alertStr.join("\n"));

获取到的结果如下:

可以看到如果选中了 将记录对象类型代码和唯一标识符作为参数传递 ,则会传递参数OrgLCID,UserLCID, id, orgname, type, typename 参数过来。

注意,从V9.0 开始,Xrm.Page.context.getQueryStringParameters 不再推荐使用了(请参考官方的 Important changes (deprecations) coming in Dynamics 365 Customer Engagement ),可以参考下面的函数来获取,函数来自David Walsh 的 Get Query String Parameters with JavaScript
        function getUrlParameter(name) {
name = name.replace(/[\[]/, '\\[').replace(/[\]]/, '\\]');
var regex = new RegExp('[\\?&]' + name + '=([^&#]*)');
var results = regex.exec(location.search);
return results === null ? '' : decodeURIComponent(results[1].replace(/\+/g, ' '));
};

在执行方法和Web资源中获取传递过来参数的值的更多相关文章

  1. web过滤器中获取请求的参数(content-type:multipart/form-data)

    1.前言: 1.1 在使用springMVC中,需要在过滤器中获取请求中的参数token,根据token判断请求是否合法: 1.2 通过requst.getParameter(key)方法获得参数值; ...

  2. Jmeter从一个Reply Message中获取N个参数的值,然后根据这个参数对后面的操作循环N次(ForEach Controller的用法)

    假设Reply Message是这样的: <root><result code="0" msg="success" /><m k= ...

  3. Java中url传递中文参数取值乱码的解决方法

    java中URL参数中有中文值,传到服务端,在用request.getParameter()方法,得到的常常会是乱码,这将涉及到字符解码操作. 方法一: http://xxx.do?ptname=’我 ...

  4. java web项目中 获取resource路径下的文件路径

    public GetResource{ String path = GetResource.class.getClassLoader().getResource("xx/xx.txt&quo ...

  5. web项目中获取spring的bean对象

    Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架,如何在程序中不通过注解的形式(@Resource.@Autowired)获取Spring配置的bean呢? Bean工厂(c ...

  6. sql 中获取最后生成的标识值 IDENT_CURRENT ,@@IDENTITY ,SCOPE_IDENTITY 的用法和区别

    原文:sql 中获取最后生成的标识值 IDENT_CURRENT ,@@IDENTITY ,SCOPE_IDENTITY 的用法和区别 IDENT_CURRENT 返回为任何会话和任何作用域中的指定表 ...

  7. 创建dynamics CRM client-side (十三) - 在HTML Web Resource中获取form elements & 获取外部js文件

    上一节我们讨论到创建HTML Web Resource. 但是纯HTML的页面不能满足我们的需求, 所以今天我们来做在HTML Web Resource中获取form elements Please ...

  8. 要在一般处理程序中获取其他页面的session值

    1.要在一般处理程序中获取其他页面的session值,需要引用名空间: using System.Web.SessionState; 2.然后继承一个接口:IRequiresSessionState, ...

  9. AOP 环绕通知 (Schema-base方式) 和 AspectJ方式在通知中获取切点的参数

    环绕通知(Schema- base方式) 1.把前置通知和后置通知都写到一个通知中,组成了环绕通知 2.实现步骤: 2.1 新建一个类实现 MethodInterceptor 接口 public cl ...

随机推荐

  1. SpringCloud的入门学习之概念理解、Feign负载均衡入门

    1.Feign是SpringCloud的一个负载均衡组件. Feign是一个声明式WebService客户端.使用Feign能让编写Web Service客户端更加简单, 它的使用方法是定义一个接口, ...

  2. PHP intdiv 数学函数

    定义和用法 intdiv - 对除法结果取整 版本支持 PHP4 PHP5 PHP7 不支持 不支持 支持 语法 intdiv ( int $dividend , int $divisor ) int ...

  3. SQL Server 查询某一个数据库存储过程、函数是否包含某一个内容或者脚本

    SELECT obj.Name 名称, sc.TEXT 内容FROM syscomments scINNER JOIN sysobjects obj ON sc.Id = obj.IDWHERE sc ...

  4. sqlserver取字符串拼音首字母

    sqlserver 使用函数获取一个字符串的拼音首字母 create function dbo.fn_getpinyin ( @str nvarchar(max) ) returns nvarchar ...

  5. SQL Serve里DBA要去改变的3个配置选项

    用安装向导安装了全新的SQL Server,最后你点击了完成按钮.哇噢~~~现在我们可以把我们的服务器进入生产了! 抱歉,那并不是真的,因为你的全新SQL Server默认配置是未优化的,一个合格的D ...

  6. 解决Python3.6.5+Django2.0集成xadmin后台点击添加或者内容详情报 list index out of range 的错误

    一 问题说明在创建Model的时候,如果存在类型是DateTimeField的字段,则在xadmin后端管理界面里,对该Model进行添加操作的时候,会报list index out of range ...

  7. LeetCode 5126. 有序数组中出现次数超过25%的元素 Element Appearing More Than 25% In Sorted Array

    地址 https://leetcode-cn.com/contest/biweekly-contest-15/problems/element-appearing-more-than-25-in-so ...

  8. poj 2431 Expedition 贪心 优先队列 题解《挑战程序设计竞赛》

    地址 http://poj.org/problem?id=2431 题解 朴素想法就是dfs 经过该点的时候决定是否加油 中间加了一点剪枝 如果加油次数已经比已知最少的加油次数要大或者等于了 那么就剪 ...

  9. 14.web4

    右键查看源代码 先进行URL解码 解码之后可以得到一串 js 代码, 具体逻辑大概就是 var p1 = "67d709b2b"var p2 = "aa648cf6e87 ...

  10. 央行辟谣未发行“DC/EP”和“DCEP” 法定数字货币仍在测试阶段

    http://www.sohu.com/a/354709423_100157595 近期,中国央行再度就法定数字货币发布公告,指出目前系统仍处于研究测试过程中,市场上交易“DC/EP”或“DCEP”均 ...