jquery chosen插件使用及select常用方法

1、chosen插件使用

chosen插件依赖于jQuery库或prototype,使用之前要先引入jQuery或prototype。

引入jquery插件和chosen插件,对需要美化的下拉框执行chosen函数:$(selector).chosen(options)。可以把selector写成样式类,这样执行完chosen函数后,只要加上样式类就可以了。

举例

<head> 
<meta charset="utf-8"> 
<link href='https://cdn.bootcss.com/chosen/1.5.1/chosen.min.css' rel='stylesheet'/>
<style>
.w-country{width:100px;}
</style>
<script src='https://code.jquery.com/jquery-1.9.0.js'></script>
<script src='https://cdn.bootcss.com/chosen/1.5.1/chosen.jquery.js'></script>
<script>
$(function(){
  $('.chosen').chosen({
        no_results_text: "没有找到结果!",//搜索无结果时显示的提示  
        search_contains:true,   //关键字模糊搜索。设置为true,只要选项包含搜索词就会显示;设置为false,则要求从选项开头开始匹配
        allow_single_deselect:true, //单选下拉框是否允许取消选择。如果允许,选中选项会有一个x号可以删除选项
        disable_search: false, //禁用搜索。设置为true,则无法搜索选项。
        disable_search_threshold: 0, //当选项少等于于指定个数时禁用搜索。
        inherit_select_classes: true, //是否继承原下拉框的样式类,此处设为继承
        placeholder_text_single: '选择国家', //单选选择框的默认提示信息,当选项为空时会显示。如果原下拉框设置了data-placeholder,会覆盖这里的值。
        width: '400px', //设置chosen下拉框的宽度。即使原下拉框本身设置了宽度,也会被width覆盖。
        max_shown_results: 1000, //下拉框最大显示选项数量
        display_disabled_options: false,
        single_backstroke_delete: false, //false表示按两次删除键才能删除选项,true表示按一次删除键即可删除
        case_sensitive_search: false, //搜索大小写敏感。此处设为不敏感
        group_search: false, //选项组是否可搜。此处搜索不可搜
        include_group_label_in_selected: true //选中选项是否显示选项分组。false不显示,true显示。默认false。
   });
   $('.chosen2').chosen({
        search_contains:false, 
        enable_split_word_search: true //分词搜索,选项词可通过空格或'[]'分隔。search_contains为false时才能看出效果
   });
});
</script>
</head>
<body>
<select class='chosen w-country' data-placeholder='请选择国家' multiple >
  <option value=""></option>
  <option value="China">中国</option>
  <option value="US">US</option>
  <option value="England">英国</option>
  <option value="Canada">加拿大</option>
  <option value="Cube">古巴</option>
</select>
<br/><br/>
<select class='chosen'>
  <optgroup label="Swedish Cars">
    <option value ="volvo">Volvo</option>
    <option value ="saab">Saab</option>
  </optgroup>
  <optgroup label="German Cars">
    <option value ="mercedes">Mercedes</option>
    <option value ="audi">Audi</option>
  </optgroup>
</select>
<br/><br/>
<select class='chosen2' >
  <option value=""></option>
  <option value="vegetable">西红柿 黄瓜 芹菜</option>
  <option value="fruit">葡萄 草莓 芭乐[潘石榴]</option>
</select>
</body>

属性:

选项 描述
data-placeholder 占位符文字。注意: 该属性会覆盖 placeholder_text_multiple 或 placeholder_text_single 选项。
multiple 有此属性的 select 会渲染成可以多选的 Chosen 选框
selected, disabled 设置选中、禁止状态,Chosen 会读取这些属性
<select class='chosen w-country' data-placeholder='请选择国家' multiple >
  <option value=""></option>
  <option value="China" selected>中国 
  <option value="Canada" disabled>加拿大</option>
</select>

监听事件:

选项 描述
change Chosen 触发标准的 change 事件,同时会传递 selected or deselected 参数, 方便用户获取改变的选项
chosen:ready Chosen 实例化完成时触发
chosen:maxselected 超过 max_selected_options 设置时触发
chosen:showing_dropdown Chosen 下拉选框打开完成时触发
chosen:hiding_dropdown Chosen 下拉选框关闭完成时触发
chosen:no_results 搜索没有匹配项时触发
$('.chosen').on('change', function(e, params) {
  do_something(e, params);
});

Chosen 触发的事件:

事件 描述
chosen:updated 通过 JS 改变 select 元素选项时应该触发此事件,以更新 Chosen 生成的选框
chosen:activate 相当于 HTML focus 事件
chosen:open 激活 Chosen 并显示搜索结果
chosen:close 关闭 Chosen 并隐藏搜索结果
$('.chosen').trigger('chosen:updated');

//我在项目中用的是
$('.chosen').trigger('liszt:updated');

常用操作:
1.1、设置chosen下拉框中的选项内容

/*设置下拉框选项内容*/
$(selectId).html(change_options);
//需要执行trigger方法,才会生效
$(selectId).trigger("liszt:updated");

1.2、设置chosen选中某项

//设置选中第几项
$(selectId).get(0).selectedIndex=i;
//需要执行trigger方法,才会生效
$(selectId).trigger("liszt:updated");

//需要执行change()方法,才会触发onChange事件
$(selectId).change();

2、select使用操作

2.1、设置select内容

清空select:
$("#ddlregtype").empty();
设置select选项
$("#ddlregtype").html();

2.2、获取select相关内容

获取select选中的 value:
$("#ddlregtype").val();
获取select 选中的 text :
$("#ddlregtype").find("option:selected").text();
获取select选中的索引:
$("#ddlregtype").get(0).selectedIndex;

2.3、设置select选中某一项

<div id="div1">
    <select id="select1">
        <option value="1">律师</option>
        <option value="2">监护人</option>
        <option value="3">亲友</option>
        <option value="4">其他</option>
      </select>
</div>

根据value值

//根据value值
$("#select1 option[value='4']").attr("selected","selected");
$("#select1 option[value='4']").attr("selected",true);
$("#select1").val("4");
$("#select1").get(0).value = '3';

根据索引值

//根据索引值
$("#select1 ").get(0).selectedIndex=index;//index为索引值(从0开始)
$("#select1").get(0).options[i].selected = true; //i为索引值(从0开始)

根据text值

//根据text值
$('#test option[text="b"]').attr("selected",true);  
$('#test').find('option[text="b"]').attr("selected",true);  

但是以上两种方法在jquery低于1.4.2的版本(含)中有效,在更高版本中无效!

【高版本Jquery中解决办法:】
解决一:精确匹配,选择文本与所给字符串完全一样的option。

$('#select1 option').filter(function(){return $(this).text()=="亲友";}).attr("selected",true);  

解决二:子串匹配,选择文本包含所给字符串的option。

$("#select1 option:contains('其他')").attr('selected', true);  

解决三:自定义函数

$("#btn").click(function(){  
    var count=$("#select1").get(0).options.length;  
    for(var i=0;i<count;i++){  
        if($("#select1").get(0).options[i].text == "亲友")    
        {  
            $("#select1").get(0).options[i].selected = true;            
            break;    
        }    
    }  
});

2.4、操作select option选项

$("#select_id").append("<option value='value'>text</option>");  //添加一项option
$("#select_id").prepend("<option value='0'>请选择</option>"); //在前面插入一项option
$("#select_id option:last").remove(); //删除索引值最大的option
$("#select_id option[index='0']").remove();//删除索引值为0的option
$("#select_id option[value='3']").remove(); //删除值为3的option
$("#select_id option[text='4']").remove(); //删除text值为4的option
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,240评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,328评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,182评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,121评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,135评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,093评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,013评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,854评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,295评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,513评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,678评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,398评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,989评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,636评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,801评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,657评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,558评论 2 352

推荐阅读更多精彩内容