xm-select多选下拉框实现拼音、首字母搜索匹配

前言

最近项目中遇到需要下拉框能实现根据首字母进行模糊搜索,下拉框使用的是xm-select,而xm-select支持中文的搜索,后端接口也仅支持中文的。因此需要借助其他插件来完成功能。

准备工作

  1. layui.js
  2. pinyin.js
  3. initials.js
  4. xm-select.js

代码

  1. 自定义搜索过滤器
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;
 };
  1. 下拉框初始化
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:[你的数据]
})
相关推荐
一丝晨光24 分钟前
数值溢出保护?数值溢出应该是多少?Swift如何让整数计算溢出不抛出异常?类型最大值和最小值?
java·javascript·c++·rust·go·c·swift
小堃学编程35 分钟前
前端学习(3)—— CSS实现热搜榜
前端·学习
Wannaer1 小时前
从 Vue3 回望 Vue2:响应式的内核革命
前端·javascript·vue.js
不灭锦鲤1 小时前
xss-labs靶场基础8-10关(记录学习)
前端·学习·xss
Bl_a_ck1 小时前
--openssl-legacy-provider is not allowed in NODE_OPTIONS 报错的处理方式
开发语言·前端·web安全·网络安全·前端框架·ssl
懒羊羊我小弟1 小时前
手写符合Promise/A+规范的Promise类
前端·javascript
互联网搬砖老肖1 小时前
Web 架构之负载均衡会话保持
前端·架构·负载均衡
赵大仁1 小时前
React vs Vue:点击外部事件处理的对比与实现
javascript·vue.js·react.js
肥肥呀呀呀2 小时前
在Flutter上如何实现按钮的拖拽效果
前端·javascript·flutter
Zero1017133 小时前
【React的useMemo钩子详解】
前端·react.js·前端框架