//C#代码

//#region OptionMetadataCollection

//OptionMetadataCollection opCollection = new OptionMetadataCollection();

//opCollection.Add(new OptionMetadata(new Label("2000年", languageCode), 2000));

//opCollection.Add(new OptionMetadata(new Label("2001年", languageCode), 2001));

//opCollection.Add(new OptionMetadata(new Label("2002年", languageCode), 2002));

//opCollection.Add(new OptionMetadata(new Label("2003年", languageCode), 2003));

//opCollection.Add(new OptionMetadata(new Label("2004年", languageCode), 2004));

//opCollection.Add(new OptionMetadata(new Label("2005年", languageCode), 2005));

//#endregion

//OptionSetMetadata optionSet = new OptionSetMetadata(opCollection);

//optionSet.Name = "new_year";

//optionSet.Description = new Label("年份", languageCode);

//optionSet.DisplayName = new Label("年份", languageCode);

//optionSet.IsGlobal = true;

//optionSet.OptionSetType = OptionSetType.Picklist;

//CreateOptionSetRequest request = new CreateOptionSetRequest();

//request.OptionSet = optionSet;

//CreateOptionSetResponse response = (CreateOptionSetResponse)service.Execute(request);

//样例

function demo() {

    //字段名称

    var attrName = "new_year";

    //标签

    var labelName = "年份";

    //语言编码

    var code = 2052;

    //集合

    var dataArray = [];

    dataArray.push(getOptionItem("2000年", 2000));

    dataArray.push(getOptionItem("2001年", 2001));

    dataArray.push(getOptionItem("2002年", 2002));

    dataArray.push(getOptionItem("2003年", 2003));

    dataArray.push(getOptionItem("2004年", 2004));

    dataArray.push(getOptionItem("2005年", 2005));

    dataArray.push(getOptionItem("2006年", 2006));

createOption(attrName, labelName, code, dataArray);


   

}

function getOptionItem(name, value) {

    var item = new Object();

    item.name = name;

    item.value = value;

    return item;

}

function createOption(attrName,labelName,code,dataArray) {

    var request = "<s:Envelope xmlns:s='http://schemas.xmlsoap.org/soap/envelope/'>";

    request += "<s:Body>";

    request += "<Execute xmlns='http://schemas.microsoft.com/xrm/2011/Contracts/Services' xmlns:i='http://www.w3.org/2001/XMLSchema-instance'>";

    request += "<request i:type='a:CreateOptionSetRequest' xmlns:a='http://schemas.microsoft.com/xrm/2011/Contracts'>";

    request += "<a:Parameters xmlns:b='http://schemas.datacontract.org/2004/07/System.Collections.Generic'>";

    request += "<a:KeyValuePairOfstringanyType>";

    request += "<b:key>OptionSet</b:key>";

    request += "<b:value i:type='c:OptionSetMetadata' xmlns:c='http://schemas.microsoft.com/xrm/2011/Metadata'>";

    request += "<c:MetadataId i:nil='true' />";

    request += "<c:HasChanged i:nil='true' />";

    request += "<c:Description>";

    request += "<a:LocalizedLabels>";

    request += "<a:LocalizedLabel>";

    request += "<c:MetadataId i:nil='true' />";

    request += "<c:HasChanged i:nil='true' />";

    request += "<a:IsManaged i:nil='true' />";

    request += "<a:Label>"+ labelName +"</a:Label>";

    request += "<a:LanguageCode>2052</a:LanguageCode>";

    request += "</a:LocalizedLabel>";

    request += "</a:LocalizedLabels>";

    request += "<a:UserLocalizedLabel i:nil='true' />";

    request += "</c:Description>";

    request += "<c:DisplayName>";

    request += "<a:LocalizedLabels>";

    request += "<a:LocalizedLabel>";

    request += "<c:MetadataId i:nil='true' />";

    request += "<c:HasChanged i:nil='true' />";

    request += "<a:IsManaged i:nil='true' />";

    request += "<a:Label>"+ labelName +"</a:Label>";

    request += "<a:LanguageCode>2052</a:LanguageCode>";

    request += "</a:LocalizedLabel>";

    request += "</a:LocalizedLabels>";

    request += "<a:UserLocalizedLabel i:nil='true' />";

    request += " </c:DisplayName>";

    request += "<c:IsCustomOptionSet i:nil='true' />";

    request += "<c:IsCustomizable i:nil='true' />";

    request += "<c:IsGlobal>true</c:IsGlobal>";

    request += "<c:IsManaged i:nil='true' />";

    request += "<c:Name>"+ attrName +"</c:Name>";

    request += "<c:OptionSetType>Picklist</c:OptionSetType>";

    request += "<c:Options> ";

    //加入详细的每一小项

    if (dataArray != null && dataArray.length > 0) {

        var len = dataArray.length;

        for (var i = 0; i < len; i++) {

            var item = dataArray[i];

            request += getItem(item.name, item.value, code);

        }

    }

    request += "</c:Options>";

    request += "</b:value>";

    request += "</a:KeyValuePairOfstringanyType>";

    request += "</a:Parameters>";

    request += "<a:RequestId i:nil='true' />";

    request += "<a:RequestName>CreateOptionSet</a:RequestName>";

    request += "</request>";

    request += "</Execute>";

    request += "</s:Body>";

    request += "</s:Envelope>";

execSoap(request);

}

function getItem(name,value,code) {

    var request = "<c:OptionMetadata>";

    request += "<c:MetadataId i:nil='true' />";

    request += "<c:HasChanged i:nil='true' />";

    request += "<c:Description i:nil='true' />";

    request += "<a:IsManaged i:nil='true' />";

    request += "<c:Label>";

    request += "<a:LocalizedLabels>";

    request += "<a:LocalizedLabel>";

    request += "<c:MetadataId i:nil='true' />";

    request += "<c:HasChanged i:nil='true' />";

    request += "<a:IsManaged i:nil='true' />";

    request += "<a:Label>" + name + "</a:Label>";

    request += "<a:LanguageCode>"+ code +"</a:LanguageCode>";

    request += "</a:LocalizedLabel>";

    request += "</a:LocalizedLabels>";

    request += "<a:UserLocalizedLabel i:nil='true' />";

    request += "</c:Label>";

    request += "<c:Value>"+ value +"</c:Value>";

    request += "</c:OptionMetadata>";

    return request;

}

//获取服务地址

function getWebUrl() {

    var serverUrl = Xrm.Page.context.getServerUrl();

    if (serverUrl.match(/\/$/)) {

        serverUrl = serverUrl.substring(0, serverUrl.length - 1);

    }

    return serverUrl + "/XRMServices/2011/Organization.svc/web";

}

//运行请求

function execSoap(request) {

    var ajaxRequest = new XMLHttpRequest();

    ajaxRequest.open("POST", getWebUrl(), true)

    ajaxRequest.setRequestHeader("Accept", "application/xml, text/xml, */*");

    ajaxRequest.setRequestHeader("Content-Type", "text/xml; charset=utf-8");

    ajaxRequest.setRequestHeader("SOAPAction", "http://schemas.microsoft.com/xrm/2011/Contracts/Services/IOrganizationService/Execute");

    ajaxRequest.send(request);

}

crm使用soap创建下拉框的更多相关文章

  1. crm使用soap更改下拉框的文本值

    //C#代码 //UpdateStateValueRequest updateStateValue = new UpdateStateValueRequest //{ //    AttributeL ...

  2. crm使用soap插入下拉框选项

    //C# 代码: //InsertOptionValueRequest request = new InsertOptionValueRequest(); //request.OptionSetNam ...

  3. crm使用soap删除下拉框

    //C# 代码: //DeleteOptionSetRequest request = new DeleteOptionSetRequest(); //request.Name = "new ...

  4. 使用ng-options指令创建下拉框

    今天在学习AngularJs中使用ng-options指令创建下拉框时遇到点问题,这里总结一下. 其实,使用ng-options指令创建下拉框很简单,只需要绑定两个属性. ng-options指令用于 ...

  5. layui 根据根据后台数据动态创建下拉框并同时默认选中

        第一步 form表单里写好一个下拉框 <div class="layui-form-item"> <label class="layui-for ...

  6. jQuery无限级联下拉框插件

    自己编写jQuery插件 之 无限级联下拉框   因为是级联,所以数据必须是树型结构的,我这里的测试数据如下: 看下效果图: 1.>图一: 2.>图二: 3.>图三: 由图可知,下拉 ...

  7. java操作poi生成excel.xlsx(设置下拉框)下载本地和前端下载

    需求:导入excel表格,如果excel有错误,将错误的地方标红,在把数据以excel的形式写出,供用户下载解决方案:1.以实体类的方式接收excel并解析(创建两个集合一个接收正常的数据一个接收错误 ...

  8. vue自定义下拉框组件

    创建下拉框组件 Select.vue <template> <div class="selects"> <div :class="{sele ...

  9. 雷林鹏分享:jQuery EasyUI 表单 - 创建树形下拉框

    jQuery EasyUI 表单 - 创建树形下拉框 树形下拉框(ComboTree)是一个带有下列树形结构(Tree)的下拉框(ComboBox).它可以作为一个表单字段进行使用,可以提交给远程服务 ...

随机推荐

  1. 基于引擎的matlab+vc混合编程的配置

    前段时间在项目中做了一些关于基于引擎的vc+matlab混合编程的工作. 如果你是混合编程新手,我相信使用引擎的方式编程是比较简单快捷的一种方式. 当然这种方法也有其缺点,就是不能脱离matlab运行 ...

  2. [置顶] Jquery发展

    jQuery在2006年1月由美国人JohnResig在纽约的barcamp发布,吸引了来自世界各地的众多JavaScript高手加入,由DaveMethvin率领团队进行开发.是继prototype ...

  3. CodePen&#39;s CSS

    p{text-indent:2em;}前端开发whqet,csdn,王海庆,whqet,前端开发专家 翻译自:CodePen's CSS 翻译人员:前端开发whqet,意译为主.不当之处欢迎大家指正. ...

  4. JDBC插入百万数据,不到5秒!

    java自带的批量操作,就可以很好的支持大量数据的处理.相比c#,简单很多.c#要使用oracle提供的ODP.NET,效率才很高,但是代码却很复杂.总之,在这方面,c#没得比.当然,这里的表是没加索 ...

  5. CSS3属性transform详解之(旋转:rotate,缩放:scale,倾斜:skew,移动:translate)(转载)

    在CSS3中,可以利用transform功能来实现文字或图像的旋转.缩放.倾斜.移动这四种类型的变形处理,本文将对此做详细介绍. 一.旋转 rotate 用法:transform: rotate(45 ...

  6. Android系统休眠对程序的影响以及处理

    Android系统在用户长时间不操作时,为了节省资源,系统会选择休眠.在休眠过程中自定义的Timer.Handler.Thread.Service等都会暂停.而有时候这种机制会影响到我们程序的正常运行 ...

  7. 终极解法According to TLD or attribute directive in tag file, attribute select does not accept any expressions

    3天硬是是把这个问题解决了 有时候突然上个厕所灵感就来了 第一次向用JSTL解析xml 然后我想遍历整个xml文档打印出来 居然不让我输入变量 那让我怎么办啊 在网上各种找答案 说什么<%@ t ...

  8. Objective-C——NSMutableURLRequest发送POST请求,使用NSJSONSerialization解析JSON字符串

    NSString *reqData = @"Data="; NSData *postDatas = nil; NSString *urlPath = @"url" ...

  9. MFC 控件初始化的过程

    之前为了学习MFC下浏览器的用法,参考博文:http://www.cnblogs.com/firefly_liu/archive/2009/05/18/1459514.html,虽然按照作者的方法实现 ...

  10. 深入理解JavaWeb技术内幕之中文编码

    为什么要编码 1.计算机中存储信息的最小单元是1个字节,所能表示的字符范围为0~255个. 2.人类要表示的符号太多,无法用1个字节来完全表示. 常见的编码类型 ASCII码 总共128个,用1个字节 ...