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

我这里有个简单的需求,就是选择了查找字段的值以后对地区字段做筛选,查找字段查找的是客户实体,客户实体上面有个所属地区字段,显示了这个客户所属的省份,然后地区就只能选择这个省份下面的城市。
对查找字段做筛选大概有三个方法,方法一:
1. 这种从我了解到的CRM 2011开始就支持了。制作一个公共视图,然后在表单上设置查找字段的属性,将默认视图设置为制作的这个公共视图,并将视图选择器关闭,如下图所示。
 
这种方式比较简单,效果如下,只能选择这个公共视图中的记录,配置简单功能也就简单。
 
方法2. 这种筛选方法从2013开始才提供,主要是使用 addPreSearch和addCustomFilter  来做,优点是页面OnLoad的时候不会执行代码,而且所加的筛选条件会应用到所有视图,缺点是它只能使用查找的实体做筛选,不能用关联的实体做筛选,这个问题 Using Linked-Entity in addCustomFilter 也有提到这个限制。我的文章 微软Dynamics CRM 2013介绍系列之三十:筛选查找控件,so easy。有介绍,这里不赘述了。 
方法3. 这种方法从CRM 2011(或许更早)就开始提供了,主要是使用 addCustomView 来做,这是今天博文要讲解的。先看看SDK中的介绍 Xrm.Page.getControl(arg).addCustomView(viewId, entityName, viewDisplayName, fetchXml, layoutXml, isDefault) ,参数含义我这里不解释了。首先是要构造一个fetchXml,使用高级查询最方便了,这里值得一提的是很多人构造的时候不加上状态等于可用这个条件,很多情况下应该加上的。
一般还需要调整列,我这里调整如下:

配置好后当然要点击 结果 查看结果是不是对的,我这里如下,是对的:

在这个结果页面点击F12按钮,打开Developer Tools这个工具,我这用的Chrome浏览器,再按Ctrl + F,输入 layoutxml 进行查找,查找到的第一个如下,刚好就是我要找的。
 
可以分别复制出来fetchxml如下:
<fetch version="1.0" output-format="xml-platform" mapping="logical" distinct="true">
<entity name="ly_district">
<attribute name="ly_districtid" />
<attribute name="ly_name" />
<attribute name="ly_districtno" />
<attribute name="ly_parentdistrict" />
<order attribute="ly_name" descending="false" />
<link-entity name="ly_district" from="ly_districtid" to="ly_parentdistrict" alias="bg">
<link-entity name="account" from="ly_district" to="ly_districtid" alias="bh">
<filter type="and">
<condition attribute="accountid" operator="eq" uiname="Adventure Works (示例)" uitype="account" value="{C223165A-3AA3-E511-80C7-000D3A807EC7}" />
</filter>
</link-entity>
</link-entity>
</entity>
</fetch>
 
复制出来的 LayoutXml 如下:
<grid name="resultset" object="10067" jump="ly_name" select="1" icon="1" preview="1">
<row name="result" id="ly_districtid">
<cell name="ly_name" width="125" />
<cell name="ly_parentdistrict" width="125" />
<cell name="ly_districtno" width="125" />
</row>
</grid>
然后就可以写代码了,注意:
1. FetchXML中查找字段筛选条件中的 uiname='湖南省' 和 uitype='ly_district' 部分可以去掉,我就把这两个属性去掉。
2. LayoutXml 中的属性preview在写代码的时候请设置为0,这样选择框好看点。
3. 复制出来的fetchxml和layoutxml中双引号替换为单引号比较好。
4. 若只能从这个筛选出来的记录选择,请在addCustomView时设置为默认视图,并且禁用选择其他视图,如下图所示:还需要在addCustomView 后执行 setDefaultView 。
5. 一般窗体的onload事件和影响这个筛选条件的字段的onchange事件都要执行相同的代码。
 
最后我所用的关键代码如下,在窗体的OnLoad事件和查找字段的onchange事件中执行如下代码:

Xrm.Page.getControl("ly_district").addCustomView("{6753B0C9-0B8C-431B-8E96-44D1D4EF6A06}", "ly_district", '地区筛选视图', "<fetch version='1.0' output-format='xml-platform' mapping='logical' distinct='false'><entity name='ly_district'><attribute name='ly_districtid'/><attribute name='ly_name'/><attribute name='ly_districtno'/><attribute name='ly_parentdistrict'/><order attribute='ly_name' descending='false'/><link-entity name='ly_district' from='ly_districtid' to='ly_parentdistrict' alias='bg'><link-entity name='account' from='ly_district' to='ly_districtid' alias='bh'><filter type='and'><condition attribute='accountid' operator='eq' value='" + (Xrm.Page.getAttribute("ly_lookup").getValue() ? Xrm.Page.getAttribute("ly_lookup").getValue()[0].id : "00000000-0000-0000-0000-000000000000") + "'/></filter></link-entity></link-entity></entity></fetch>", "<grid name='resultset' object='10067' jump='ly_name' select='1' icon='1' preview='0'><row name='result' id='ly_districtid'><cell name='ly_name' width='125'/><cell name='ly_parentdistrict' width='125'/><cell name='ly_districtno' width='125'/></row></grid>", true);
Xrm.Page.getControl("ly_district").setDefaultView("{6753B0C9-0B8C-431B-8E96-44D1D4EF6A06}");

效果如下,不能选择到其他视图,只能在限定的范围内选择。
 

查找字段的筛选-使用addCustomView的更多相关文章

  1. mysql通过字段注释查找字段名称

    原文:mysql通过字段注释查找字段名称 有时候表的字段太多,只是大致记得表的注释,想通过字段注释查找字段名称,可以用如下语句: SELECT COLUMN_NAME,column_comment F ...

  2. openEntityForm时候如何给关于(regardingobjectid)类型查找字段赋值?

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

  3. Dynamics 365中使用Web API将查找字段的值设置为空值的方法。

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

  4. Dynamics CRM2016 Web Api之查询查找字段的相关属性

    之前有篇博文介绍了如何获取查找字段的name值(跳转),本篇在此基础上再延伸下,实现的效果类似于EntityReference,可以取到查找字段的id,name,localname. 这里我以客户实体 ...

  5. Dynamics CRM2016 Web API之删除单个查找字段值

    之前的博文中有介绍过,Web Api中的一个删除单个属性的Api但没提供查找字段的删除方法,本篇补充上,这里给出的示例代码是C#的(主要看url的拼接),看下url中最后的/$ref,这个标示表明了当 ...

  6. openEntityForm如何给关于(regardingobjectid)类型查找字段赋值?

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

  7. Sed+Grep 快速替换查找字段(批量替换字符串)

    格式: sed -i "s/查找字段/替换字段/g" `grep 查找字段 -rl路径` 命令分解: grep 查找字段 -rl路径   列出”路径”中” 查找字段” 的所有文件 ...

  8. mysql通过字段凝视查找字段名称

    有时候表的字段太多.仅仅是大致记得表的凝视,想通过字段凝视查找字段名称,能够用例如以下语句: SELECT COLUMN_NAME,column_comment FROM INFORMATION_SC ...

  9. ORACLE 查找字段在哪些表里存在

    查找不是主键的字段在哪些表里存在: select owner, table_namefrom dba_tab_columnswhere lower(column_name)='firstname'; ...

随机推荐

  1. C# Serialization performance in System.Runtime.Serialization.Formatters.Binary.BinaryFormatter,Newtonsoft.Json.JsonConvert and System.Text.Json.JsonSerializer.Serialize

    In .net core 3.0 using System;using System.Collections.Generic;using System.Collections;using System ...

  2. Redis报错:ERR This instance has cluster support disabled

    异常分析从报错误的信息ERR This instance has cluster support disabled很明显看得出来,是没有启动redis集群功能,可是我项目配置的集群的配置方式,要么修改 ...

  3. 利用Azure虚拟机安装Dynamics 365 Customer Engagement之二:创建域控虚拟机

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  4. 未能找到元数据文件**.dll解决办法

    解决方案里有很多项目.生成时提示100多个错误,都是未能找到元数据文件**.dll. 那就清理一下解决方案,一个一个来吧. 生成GateWay.Utilities项目时,虽然提示成功了,却发现bin/ ...

  5. Ubantu 安装SSH

    1.检查是否安装SSH dpkg --get-selections | grep ssh 一般情况下Ubantu 默认集成 openssh-client,但要用sftp的话还需要安装openssh-s ...

  6. 'Specifying a namespace in include() without providing an app_name '

    'Specifying a namespace in include() without providing an app_name ’ 从include()函数可以看出来,这个函数有两个参数,一个a ...

  7. docker上启动nginx,并配置修改nginx的配置文件

    1.使用docker 下载nginx 镜像  docker pull nginx 2.启动nginx docker run --name nginx -p 80:80 -d nginx 这样就简单的把 ...

  8. 一个EMFILE问题定位:lsof、ulimit的应用,以及简单分析

    关键词:errno.EMFILE.ulimit.lsof等等. 背景是在对程序进行压力测试,运行了一段时间之后出现一个复位操作失败. 这个复位操作通过打开一个设备,进行读写操作,已达到控制GPIO输入 ...

  9. CK:User mode Bus Error(用户空间操作内核地址导致的异常)

    关键词:VEC_ACCESS.coredump.LR.PC等. CK中存在一种VEC_ACCESS异常,可能原因是用户空间访问了内核空间,还有一种是内核访问不存在的总线地址. 下面简单构造VEC_AC ...

  10. Unity如何更改精灵中心点

      Unity虽然可以改中心点但是仅支持几个特定位置. 如果是一个你是切割的精灵,则可以进入精灵编辑器中调整 打开精灵编辑器后按调整如下图所示的pivot选项,我在这里把精灵调整成了右上. 在精灵编辑 ...