插件官网:https://select2.github.io/examples.html

  页面引入:

// 页面顶部
<link rel="stylesheet" type="text/css" href="css/select2.min.css"> // 页面底部
// 依赖jQuery,引入jQuery之后,还需引入以下js文件
<script type="text/javascript" src="js/select2/select2.full.min.js"></script>
<script type="text/javascript" src="js/select2/lang/zh-CN.js"></script>

  调用select2

var util = {
select2: function(options){
select2(options); //将输入的值作为其值
var inputAsValue = function($target, value){
var id = "select2-" + $target.attr("id") + "-container";
$("#advertiser_name_input").val(value).keyup();
$("#"+id).text(value);
}; function select2(arg) {
var requireName = arg.requireName;
arg.target.select2({
placeholder:arg.placeholder, // 文本框的提示信息
language: 'zh-CN',
         // 若不想引入zh-CN.js文件,可注释上一句,改为下面的即可
         /*
          language: {

            noResults: function() {
              return"未找到结果"
            } ,searching: function() {
              return"搜索中…"
            }

          }
         */
   minimumInputLength: 1, // 至少输入n个字符,才去加载数据;若设置为0,则点击选择框,不用输入内容,就去加载数据;默认为0
maximumInputLength: 100, // 限制最大字符,以防坑
                data: options.data,
ajax: {
url: arg.url,
dataType: 'json',
method: 'post',
quietMillis:100,
delay: 250,
data: function (params) {
var data = {}, id;
data[arg.requireName] = params.term; // 查询的关键字
// data['page'] = params.page;
return $.extend(true, data, arg['other']);
},
processResults: function (result, params) {
            // params.page = params.page || 1;
if(result && result.flag && !$.isEmptyObject(result.data)){
var resultData = result.data,
selectData = [], selectObj = {};
for(var i=0,len=resultData.length; i<len; i++){
selectObj = {
'id': resultData[i]['id'] || '',
'text': resultData[i]['name'] || '',
'industry_id': resultData[i]['industry_id'] || ''
};
selectData.push(selectObj);
}
return {
/* pagination: {
more: (params.page * 30) < 100 //data.total_count
},*/
results: selectData
};
}else{
var noData = [
{id:0,text:'暂无数据'}
];
return {
results:noData
};
}
},
cache: true
},
escapeMarkup: function (markup) { return markup; }
});
arg.target.on("change", function(e){
options.change && options.change();
});
}
}
}; // 调用
util.select2({
target: $('#select'),
url: pageInfo.activityNameUrl,
requireName: 'key',
callback: '',
data: {'id', 11},
change: function(){
var $select = $('#select');
var data = $select.select2("data")[0];
// 其余操作
}
});

  注意:注释的代码可以实现分页功能, 鼠标拖动滚动条往下滚时,再去请求再显示下一页的效果;但是需要后台支持,根据请求参数page的页数,返回响应的数据。

  设置默认值或回填值:

 if(selectId !=''){
$("#select").html('<option value="'+selectId +'">'+selectVal+'</option>').trigger('change');
}

  显示全部:

名称:<select class="select-w100 select2" name="select" id="select">
<option value="">全部</option>
</select>

  获取值(多选值,默认用逗号分隔):

获取多选值
$('#save-btn').click(function(){
var city = $('#city').val();
var cityDesc = $('#city option:selected').text();
})

  特殊地方:select2下拉框插件,可以做多选,但是每选一次就会收起一次下拉。
  逐个勾选,多选完后,点击下拉框外面的区域再收起。

  可以设置:closeOnSelect: false

select2插件使用小记的更多相关文章

  1. select2插件使用小记2 - 多选联动 - 笔记

    这是select2插件使用的第二篇,可参考第一篇 select2插件使用小记.上一篇主要是关于基本的使用,这篇主要是关于多选,及联动的.侧重点不同. 效果图如下: 遵从W3C标准:结构.样式.行为.以 ...

  2. select2插件

    引入select2插件<link href="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.3/css/select2.min. ...

  3. 基于Metronic的Bootstrap开发框架经验总结(3)--下拉列表Select2插件的使用

    在上篇<基于Metronic的Bootstrap开发框架经验总结(2)--列表分页处理和插件JSTree的使用>介绍了数据的分页处理,使用了Bootstrap Paginator插件,另外 ...

  4. Metronic_下拉列表Select2插件的使用

    这个插件是基于Select的扩展插件,能够提供更加丰富的功能和用户体验,它的github官网地址为:https://select2.github.io/,具体的使用案例,可以参考地址:https:// ...

  5. jQuery的下拉选select2插件用法

    1转自:https://www.jb51.net/article/95561.htm 用了这么久的Select2插件,也该写篇文章总结总结.当初感觉Select2不是特别好用,但又找不到比它更好的下拉 ...

  6. select2插件用法

    1.修改默认查询方法,使其可以根据value查询 this.element.select2({ allowClear: true, matcher: function (term, text, ele ...

  7. Select2插件的隐藏、设置宽度

    <select id="selPrinvice" class="Select2 select2-hidden-accessible" style=&quo ...

  8. 01:jQuery的下拉选select2插件用法

    1.1 select2插件基本使用 1.下载select2插件 1. 下载地址:https://github.com/select2/select2 2.官网地址:https://select2.or ...

  9. 在select2插件中append下拉选,点击没反应的解决

    今天前端大佬帮我解决了一个棘手的问题:克隆了已有系统的网页,尝试把复制下来的html改造成jsp.基本功能正常,然而点击新增按钮,出来的行无法点击下拉选,控制台也没报错. 项目用的是jeesite2. ...

随机推荐

  1. c#的装箱和拆箱及值类型和引用类型

    装箱:它允许根据值类型创建一个对象,然后使用对这新对象的一个引用. int i = 5; object o = i; int j = (int)o; 装箱:运行时将在堆上创建一个包含值5的对象(它是一 ...

  2. 《从0到1》深度阅读笔记zz

    没有人能精准地预测未来,我们只知道两件事:一是世界必然会变得不同:二是现在再好的描述也不能让我们看到清晰的未来. 创业者把成就归功于商业模式和机会窗口,归功于创业者本人拥有的资源和能力,但还有一个最重 ...

  3. 如何将frm文件导入MySql数据库

    只要在mysql的安装文件中找到data文件夹,然后在里面建立一个文件夹,比如test.这个test其实就对应着数据库的名称,所以,你想要起什么样的数据库名称就把文件夹起什么名字. 然后把.frm文件 ...

  4. codeforces题目合集(持续更新中)

    CF280CCF280CCF280C 期望dp CF364DCF364DCF364D 随机化算法 CF438DCF438DCF438D 线段树 CF948CCF948CCF948C 堆 CF961EC ...

  5. 关于拼接SQL语句sqlMap的使用方法

    1.为什么使用? 主要还是为了代码中获取到值,然后带入SQL语句中拼接查询 2.怎么使用? 1)bean继承了BaseEntity类,该类中有 /** * 自定义SQL(SQL标识,SQL内容) */ ...

  6. Location对象的查询字符方法实现

    function getQueryStringArgs(){ /*如果location.search有则删除第一个字符,并返回删除后的字符串*/ var gs = (location.search.l ...

  7. i2c_client 几种实例化方法

    http://blog.csdn.net/lugandong/article/details/48092397

  8. WordPaster-CuteEditor6.7整合教程

    CuteEditor6.7下载地址:http://yunpan.cn/QzvjC5iaH5HJm 1.添加CuteEditor.dll的引用 2.在编辑器页面,为编辑器工具栏增加控件按钮 3.在前台增 ...

  9. 2.2.2synchronized同步代码块的使用

    当两个并发线程访问同一个对象object中的synchronized(this)同步代码块时,一段时间内只能有一个线程执行,另一个线程必须等待期执行完才能执行. package com.cky.bea ...

  10. 2018-03-17 handler学习使用

    1.handler具体使用https://www.cnblogs.com/JohnTsai/p/5259869.html 2.handlerThread用法https://www.jianshu.co ...