前言
最近项目中遇到需要下拉框能实现根据首字母进行模糊搜索,下拉框使用的是xm-select,而xm-select支持中文的搜索,后端接口也仅支持中文的。因此需要借助其他插件来完成功能。
准备工作
- layui.js
- pinyin.js
- initials.js
- xm-select.js
代码
- 自定义搜索过滤器
typescript
//搜索过滤器
var myFilter_xmSel = function (value, text, id) {
//value:输入值; text:option的text值;id:option的value值;
var result;
if (escape(value).indexOf("%u") != -1) { //汉字
result = text.indexOf(value) > -1;
} else {
var len = value.length;
result = ConvertPinyin(text).substring(0, len) === value || makePy(text)[0].toLowerCase().substring(0, len) === value || text.toLowerCase().indexOf(value) > -1 || (id === undefined ? false : id.indexOf(value) > -1);
}
return result;
};
- 下拉框初始化
typescript
let xmSel = xmSelect.render({
el: '#sel',
name: 'sel',
model: {
label: {
type: 'text'
}
},
radio: true,
//选中关闭
clickClose: true,
filterable: true,
filterMethod: function (val, item, index, prop) {//重写搜索方法。
if (val == item.value) {//把value相同的搜索出来
return true;
}
if (item.name.indexOf(val) != -1) {//名称中包含的搜索出来
return true;
}
return myFilter_xmSel(val, item.name, item.value);
},
data:[你的数据]
})