前端之家收集整理的这篇文章主要介绍了
Angularjs实现带查找筛选功能的select下拉框示例代码,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
前言
对于select的下拉列表,像国家选择这样的功能,全世界那么多国家,一直拉滚动条多辛苦,眼睛也要盯着找,累!所以为优化用户体验,带查找功能的下拉框是非常非常有必要的。都知道jquery里有这样的插件,但我们用的是Angularjs,更希望用双向绑定,指令的方式优雅地解决这个问题。
分析
我们的目标是在原来的
问题
1.在selectSearch
指令里,怎么获取到ng-options
里的数据源,以及指定的
value(option标签的value)
和
text(option标签里的text)
字段名。
2.用什么方式来筛选?是每次显示匹配项,隐藏不匹配项还是毎次从数据源里匹配,重新生成结点。
1.参考angular自带指令ng-options
来获取数据源和value
,text
字段名。特别说明,仅支持ng-options="obj.value as obj.text for obj in list"
的普通形式,那些带分组的等等,暂不支持哈。
2.重新生成结点。(为什么这么选择,方便呀!)
具体实现
1.代码部分
1.1 js代码(请引先引入jquery,不然会报错)
功能的下拉框
* 使用
方法 ' +
'<div class="chose-drop chose-hide j-drop">' +
'<div class="chose-search">' +
'<input class="j-key" type="text" autocomplete="off">' +
'