引用:

<script src="~/Content/plugins/select2/select2.min.js"></script>

1.简单使用

$.getJSON("/Basic/GetWareList", {}, function(data) {
$("#form_ware").select2({ data: data });
});

--根据value选中

$("#form_ware").val('20007').trigger("change");

--根据text选中

$("#form_ware option:contains('华南仓')").attr('selected', true).trigger("change");

--清空

$("#form_ware").empty();

--取值

$("#form_ware").select2('data')[0].id;
$("#form_ware").select2('data')[0].text; $("#form_ware").select2('data')[0].obj; //获取附加值

2.级联使用

初始化信息

$("#form_province").select2({
   data: [{ id: -1, text: "请选择" }]
});

省市县级联

//初始化地址信息
$("#dl_province").select2({
data: [{ id: -1, text: "请选择" }]
});
$("#dl_city").select2({
data: [{ id: -1, text: "请选择" }]
});
$("#dl_county").select2({
data: [{ id: -1, text: "请选择" }]
}); //加载省
$.getJSON("/Basic/GetAddressList", { type: "2", parent_id: "1", default_text: "请选择" }, function (data) {
$("#dl_province").select2({
data: data
});
}); //加载市
$("#dl_province").change(function (e) { $("#dl_city").empty();
$("#dl_city").select2({
data: [{ id: -1, text: "请选择" }]
}); $("#dl_county").empty();
$("#dl_county").select2({
data: [{ id: -1, text: "请选择" }]
}); var dl_province = $("#dl_province option:selected").val();
if (dl_province != "-1") {
$.getJSON("/Basic/GetAddressList", { type: "3", parent_id: dl_province, default_text: "请选择" }, function (data) {
$("#dl_city").select2({
data: data
});
});
}
}); //加载县
$("#dl_city").change(function (e) {
$("#dl_county").empty();
$("#dl_county").select2({
data: [{ id: -1, text: "请选择" }]
}); var dl_city = $("#dl_city option:selected").val();
if (dl_city != "-1") {
$.getJSON("/Basic/GetAddressList", { type: "4", parent_id: dl_city, default_text: "请选择" }, function (data) {
$("#dl_county").select2({
data: data
});
});
}
});

3.后端帮助方法

public class ToSelect2Data<T> where T : class
{
public static List<Select2DataModel<T>> ToSelectData(List<T> model, string IdKey, string TextKey)
{
List<Select2DataModel<T>> m = new List<Select2DataModel<T>>();
foreach (var item in model)
{
Type t = item.GetType();
Select2DataModel<T> s = new Select2DataModel<T>();
PropertyInfo idInfo = t.GetProperty(IdKey);
s.id = idInfo.GetValue(item, null).ToString(); PropertyInfo textInfo = t.GetProperty(TextKey);
s.text = textInfo.GetValue(item, null).ToString(); s.obj = item;
m.Add(s);
}
return m;
}
} public class Select2DataModel<T> where T : class
{
public string id { get; set; }
public string text { get; set; }
public T obj { get; set; }
}

使用方法(id,name 是list集合的字段名)

 return Json(ToSelect2Data<bs_addr>.ToSelectData(addressList, "id", "name"), true);

Select2使用方法汇总的更多相关文章

  1. 你真的会玩SQL吗?实用函数方法汇总

    你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...

  2. Java实现时间动态显示方法汇总

    这篇文章主要介绍了Java实现时间动态显示方法汇总,很实用的功能,需要的朋友可以参考下 本文所述实例可以实现Java在界面上动态的显示时间.具体实现方法汇总如下: 1.方法一 用TimerTask: ...

  3. C#读写文件的方法汇总_C#教程_脚本之家

    C#读写文件的方法汇总_C#教程_脚本之家 http://www.jb51.net/article/34936.htm

  4. UITextView实现placeHolder方法汇总

    UITextField中有一个placeholder属性,可以设置UITextField的占位文字,起到提示用户的作用.可是UITextView就没那么幸运了,apple没有给UITextView提供 ...

  5. 将编码从GB2312转成UTF-8的方法汇总(从前台、程序、数据库)

    这篇文章主要介绍了将编码从GB2312转成UTF-8的方法汇总(从前台.程序.数据库),需要的朋友可以参考下 一个网站如果需要国际化,就需要将编码从GB2312转成UTF-8,其中有很多的问题需要注意 ...

  6. 本地获取System权限CMD方法汇总(转)

    本地获取System权限CMD方法汇总(转) 稍微整理了下,大概有三种方法可以本地获取system权限的cmd,但前提都是当前用户具备administrator权限. 下面列举的三种方法各有千秋,看你 ...

  7. Javascript对象属性与方法汇总

    Javascript对象属性与方法汇总 发布时间:2015-03-06 编辑:www.jquerycn.cn 详细介绍下,javascript对象属性与对象方法的相关知识,包括javascript字符 ...

  8. .net(C#)操作文件的几种方法汇总

    .net(C#)操作文件的几种方法汇总 System.IO命名空间下类的用法:在System.IO名称空间中包含了用于文件输入输出的主要类.File:实用类,提供许多静态方法,用于移动.复制和删除文件 ...

  9. jquery常用函数与方法汇总

    1.delay(duration,[queueName]) 设置一个延时来推迟执行队列中之后的项目. jQuery1.4新增.用于将队列中的函数延时执行.他既可以推迟动画队列的执行,也可以用于自定义队 ...

随机推荐

  1. 【Codeforces Round #185 (Div. 2) D】Cats Transport

    [链接] 链接 [题意] 有n座山,m只猫. 每只猫都在其中的一些山上玩. 第i只猫在h[i]山上玩,且会在t[i]时刻出现在山脚下(然后就一直在那里等) 然后有p个人. 它们听从你的安排. 在某个时 ...

  2. Windows平台CUDA开发之前的准备工作

    CUDA是NVIDIA的GPU开发工具,眼下在大规模并行计算领域有着广泛应用. windows平台上面的CUDA开发之前.最好去NVIDIA官网查看说明,然后下载对应的driver. ToolKits ...

  3. hprof教程 分类: B1_JAVA 2015-03-02 12:18 444人阅读 评论(0) 收藏

    大部分内容参考http://www.linuxidc.com/Linux/2012-04/58178.htm J2SE中提供了一个简单的命令行工具来对java程序的cpu和heap进行 profili ...

  4. Python 奇葩语法

    a = 1, 2, 3 赋值后的结果,a == (1, 2, 3),将一个元组(tuple)赋给了变量 a (1, 2) + (3, ) ⇒ (1, 2, 3),并不能说明 tuple 可以添加新的元 ...

  5. JMS是一种应用于异步消息传递的标准API

    JMS是一种应用于异步消息传递的标准API,作为Java平台的一部分,JMS可以允许不同应用.不同模块之间实现可靠.异步数据通信.一些概念 JMS provider    An implementat ...

  6. Android shape画圆点

    <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http: ...

  7. [Angular] Angular CLI

    Create an app with routing config: ng new mynewapp --routing If you want to generate a new module wi ...

  8. Android的NDK开发(3)————JNI数据类型的详解

    在Java中有两类数据类型:primitive types,如,int, float, char:另一种为reference types,如,类,实例,数组. 注意:数组,不管是对象数组还是基本类型数 ...

  9. 【iOS】怎样推断文本文件的字符编码格式

    整体思路: 遍历全部的字符编码.能正确读取输出转换的就是文本文件的编码格式. 代码例如以下: // // main.m // 检測文本字符编码格式的小技巧 // // Created by 杜子兮 ( ...

  10. hbase 从hdfs上读取数据到hbase中

    <dependencies> <dependency> <groupId>org.apache.hbase</groupId> <artifact ...