EasyUI combobox下拉列表实现搜索过滤(模糊匹配)

  项目中的某个下拉列表长达200多个项,这么巨大的数量一个一个找眼镜都得看花,于是就得整了个搜索功能。看网上别人帖子有只能前缀匹配的方案,但只能前缀匹配的话用起来也不是很方便。于是就记录一下模糊匹配的方案。

实现效果:

这里使用的是combobox组合框,对于combobox的创建可以使用<input>输入框,也可以使用<select>下拉选。我使用的是<select>:

HTML代码

<label>关联课程</label>
<select class="easyui-combobox" name="itemsId" id="itemsId" style="width:135px;height:25px;">
    <option>请选择关联课程</option>
</select>

然后通过js从远程获取数据并实现搜索功能:

$("#itemsId").combobox({
                 url: "xxxxxx",
                 editable: true,
                 valueField: ‘id‘,
                 textField: ‘name‘,
                 panelWidth: 220,   // 下拉框宽度
                 panelHeight: 250,  // 下拉框高度
                 filter: function(q, row){
                     var opts = $(this).combobox(‘options‘);
                     return row[opts.textField].indexOf(q) > -1;
                 }
            });    

因为需要输入查询,所以下拉项必须得可编辑。使用combobox创建下拉项默认是可以编辑的,设置 editable: true 虽然感觉很鸡肋,但看起来功能更清晰。

filter:定义函数如何过滤数据,return row[opts.textField].indexOf(q) == 0时只能前缀匹配,  return row[opts.textField].indexOf(q) > -1 就是模糊匹配了。

  这样模糊匹配的功能就实现了。随便记录一下默认显示值的问题。

在修改数据时默认得显示设置的值,也就是加载的选择项selected=true,一开始我是想使用formatter函数将获取的列表数据选中的项添加selected属性为true,但这种方式会导致下拉列表显示为空白

所以这种方式是不可行的,于是就寻求了其他方式,发现了解决方案:

通过combobox的select方法:

只需添加下面这行代码就行,在combobox创建前后都可以。

$("#itemsId").combobox("select", rows.name)

这是通过combobox的select方法选择指定的选项,“rows.name”可以是option的value,也可以text。

当然也可以在combobox的onLoadSuccess事件,从远程数据加载成功时处理(这种方式就太累赘了,只是为了记录一下onLoadSuccess的使用):

$("#itemsId").combobox({
                 url: ‘xxxx‘,
                 editable: true,
                 valueField: ‘id‘,
                 textField: ‘kcName‘,
                 panelWidth: 220,
                 panelHeight: 250,
                 filter: function(q, row){
                     var opts = $(this).combobox(‘options‘);
                     return row[opts.textField].indexOf(q) > -1;
                 },
                 onLoadSuccess: function(data) {
                     for(var i = 0; i < data.length; i++) {
                         if(data[i].id == rows.itemsId) {
                             $("#itemsId").combobox("select", data[i].id)
                         }
                     }
                 }
            });    

原文地址:https://www.cnblogs.com/qq545505061/p/11294372.html

时间: 2024-10-02 08:17:14

EasyUI combobox下拉列表实现搜索过滤(模糊匹配)的相关文章

jquery easyui combobox 从指定位置开始模糊查询

$("#bzr").combobox({ url: "ClassSave.aspx?opt=bzr&bzr=<%=arrbj[2]%>", valueField: "value", textField: "text", mode: "local", filter: function (q, row) { var opts = $(this).combobox('options'); va

Extjs 3实现Combobox下拉列表的拼音过滤

下拉列表是我们常用的表单元素,能够通过选项的方式代替手动输入,提高输入效率和准确率.但有时侯,如果下拉列表中选项过多,在选择中就会造成不便,降低输入效率. 比如12306火车票订票系统中,发站和到站框中,从下拉列表中选择就非常困难.在日常使用中经常使用输入文字拼音首字母(简拼.音序)的方式进行可选项的过滤,现在我们尝试在Extjs3中使用这种方式,Extjs其他版本可参考. 要通过汉字得到对应的拼音,方式是多种多样的.第一种是在数据库中加字段保存可选项的简拼,这种方式需要操作人员手动维护可选项的

高亮显示 筛选 搜索元素 模糊匹配 多关键词搜索

//模糊匹配 check.onclick = function(){ for(i = 0;i<ul.children.length;i++){ var list = ul.children[i].innerHTML; var inputValue = inPut.value; if(list.search(inputValue) != -1){ ul.children[i].style.background = 'yellow'; // 注意这里不可以再用list这个变量了,也不能是innerh

NSPredicate 谓词总结 数组过滤 模糊匹配

NSPredicate 用于指定过滤条件,主要用于从集合中分拣出符合条件的对象,也可以用于字符串的正则匹配. NSPredicate常用方法介绍 [objc] view plaincopy 1.创建NSPredicate(相当于创建一个过滤条件) NSPredicate *predicate = [NSPredicate predicateWithFormat:@"过滤条件"]; 2.判断指定的对象是否满足NSPredicate创建的过滤条件 [predicate evaluateWi

下拉列表实现模糊匹配选择

最近在做一个在文本框输入关键字, 文本框下动态显示加载相关内容的下拉列表的效果, 就是类似于百度和淘宝搜索框这种效果. 不断的研究加上尝试, 得到两种方案解决这个需求, 特意记录一下, 以免下次用的时候忘记. 方法一: HTML5新增的datalist标签 HTML5作为当下最为热门的 Web 技术, 已经在互联网行业得到了普遍应用, 基于HTML5的浏览器和Web引擎为用户带来了感知体验上的巨大飞跃, 并将Web应用带入了一个新的发展阶段, 可以预见HTML5会有更广泛的使用及更好的发展. H

easyui datagrid combobox 模糊匹配的问题

最近遇到的问题,datagrid中有动态添加的combobox,combobox已经修改为模糊匹配,而不是原来的从左到右匹配,但是在我的combobox里面有许多类似项,没办法,只能让valueFiled 为唯一值,但是保存后本来该单元格要显示valuefiled,而valuefiel必须是中文,如图,纠结了很久,突然想到在下拉框隐藏的时候,就把combobox('setText',mc);combobox('setValue',mc) 这样子,在下拉框隐藏的时候,显示的是中文,改行提交后,单元

easyui combobox开启搜索自动完成功能

combo.json [{ "id":-1, "text":" ", "spell":"" },{ "id":1, "text":"类型1", "spell":"lx1" },{ "id":2, "text":"类型2", "spell&q

easyui combobox 本地数据实现输入中文拼音简码过滤数据

<pre name="code" class="html"><input class="easyui-combobox" name="language" data-options=" data: baseData.emp.ck, width: 105, height: 26, valueField: 'id', textField: 'text', inputCode: 'inputCode', /

Linux使用技巧——find结合grep模糊匹配文件搜索关键字

find结合grep模糊匹配文件搜索关键字 不知道哪个单词在哪个文件里面可以使用这种方法 [[email protected] window_books]# find . -name "*txt" -type f | xargs grep "description" ./2013_liuyinan_5500_words_21-32.txt:1309 description ?????????????? n. 描写,形容:种类 ion-名词后缀 ./2013_liuy