我的博客第一篇文章---下拉框

这篇文章主要为大家详细介绍了jQuery插件实现可输入和自动匹配的下拉框,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

 

 

1.直接使用h5的新标签<datalist>,对应demo如下:

1

2

3

4

5

6

7

8

<inputlist="browsers">

<datalistid="browsers">

 <optionvalue="Internet Explorer">

 <optionvalue="Firefox">

 <optionvalue="Chrome">

 <optionvalue="Opera">

 <optionvalue="Safari">

</datalist>

优点:节约js代码;

缺点:IE 9及以下的IE浏览器 和 Safari 均不支持 <datalist> 标签(好像还有几个浏览器也不支持);重复点击输入框或者下拉图标并不能收回下拉列表;样式难以控制

2.使用基于jQuery的select2插件(需要同时引入select2.css和select2.js),html部分代码如下:

1

2

3

4

5

6

<selectclass="select2_test">

 <option></option>

 <optionvalue="1">1</option>

 <optionvalue="2">2</option>

 <optionvalue="3">3</option>

</select>

js部分代码如下:

1

2

3

4

$('.select2_test').select2({

 placeholder:"请选择所属选项",

 allowClear:true;

});

注意:与bootstrap的Modal模态框结合使用时,会出现下拉列表出现在遮罩层的底层和点击弹出框关闭按钮但下拉列表并没有消失的问题,找了半天原来问题出在select2.css这个样式表中,

原因:点击输入框,此插件会生成一个遮罩层(类名为.select2-drop-mask)和一个下拉列表(类名为.select2-drop),这两者的层叠性(z-index)依次为9991,9992,但是modal弹出框的层叠性大于10000,所以才会导致出现上述两个问题

解决办法:如果将.select2-drop-mask和.select2-drop的z-index分别提高到19991、19992,下拉列表成功显示在上面,但在打开了下拉列表的前提下点击modal弹出框的关闭按钮会先收回下拉框,再次点击才能关闭弹出窗,用户体验不是很好;这里可以尝试提高关闭按钮的z-index,前提一定要父元素不能是modal弹出框,否则其提高的z-index无效。

如果想更深入了解select2.js插件,可以参考http://www.jb51.net/article/95561.htm

3.造成select2.js上述不适的主要原因在于.select2-drop的失去焦点是要点到select2-drop-mask上才能触发,为改善这种机制,这里推荐另一款基于jQuery的下拉搜索框插件magicsuggest(需要同时引入magicsuggest.css和magicsuggest.js),html部分很简单,直接就是:

<div id="magicsuggest"></div>

js部分代码如下:

1

2

3

4

5

6

7

8

9

10

11

12

$('#magicsuggest').magicSuggest({

  placeholder:''

  allowFreeEntries:false,

  maxSelection:1,

  autoSelect:true,

  valueField:"id",

  displayField:"value",

  resultAsString:true,

  selectionStacked:true,

  highlight:false,

  data: ['Paris','New York','Gotham']

});

优点:不会出现层叠性冲突的问题;样式美观;允许多项选择

缺点:多余的样式较多(阴影、高亮、错误提示、多选),需要根据具体需要调整样式;不能直接通过$(this).val()来获取原输入框的值;数据量过大时加载会出现延迟

4.鉴于上面那个插件默认的是多选的样式,用到项目里也不能直接获取<select>标签里的值,这里我个人推荐chosen这款插件(需要同时引入chosen.css和chosen.js),html部分代码如下:

1

2

3

4

5

6

7

8

9

10

11

<selectdata-placeholder="Type 'C' to view" style="width:100%"class="myselect chosen-select-no-results" tabindex="10">

 <optionvalue=""></option>

 <option>American Black Bear</option>

 <option>Asiatic Black Bear</option>

 <option>Brown Bear</option>

 <option>Giant Panda</option>

 <option>Sloth Bear</option>

 <option>Sun Bear</option>

 <option>Polar Bear</option>

 <option>Spectacled Bear</option>

</select>

 js部分代码如下:

1

2

3

4

5

6

7

8

9

10

varconfig = {

  '.chosen-select':{},

  '.chosen-select-deselect':{allow_single_deselect:true},

  '.chosen-select-no-single':{disable_search_threshold:10},

  '.chosen-select-no-results':{no_results_text:'Oops, nothing found!'},

  '.chosen-select-width':{width:"95%"}

}

for(varselectorinconfig) {

  $(selector).chosen(config[selector]);

}

注意:如果与bootstrap的Modal模态框结合使用时,会出现下拉列表显示不出来, 同时.modal-body右侧出现滚动条,原因就在于bootstrap给.modal-body设置了一个overflow-y:auto的默认样式,所以解决办法就是给.modal-body添加一个overflow-y:visible的样式来覆盖它。

5.当然,实现相同功能的jQuery插件还有很多,具体可以参考http://www.cnblogs.com/lhb25/p/form-enhanced-with-javascript-three.html

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值