vue中利用pinyin-pro纯前端实现拼音的模糊搜索

1、安装配置插件

pinyin-pro官网网址:

pinyin-pro - npm (npmjs.com)

 

npm 安装

npm install pinyin-pro

 

项目中引入

import { pinyin } from 'pinyin-pro';

 

2.编写工具类方法

定义三个变量:

复制代码
// 双向绑定搜索框,由用户输入的数据
inputProvince: 'ninxia',

// 从后台获取的,筛选前的总数据
totalProvinceList: [
{ province: '宁夏省',id:'0001', turnover: '50' },
.....
],
// 由inputProvince从totalProvence中筛选后的数据,双向绑定列表
provinceList: [],
复制代码

 

编写方法:

在vue中定义方法用的是mehtod(){return 0}的形式,其他框架中视情况改变定义的办法

复制代码
    // 输入框搜索有关方法

    pinyinFilter (inputValue, totalList) { // 工具类方法,从数组中过滤出汉字、拼音、拼音首字母相同的项
      /* 输入内容拼音转换 */
      // 完整拼音
      const pyInput = pinyin(inputValue, { toneType: 'none', type: 'array' }).join('')
      console.log('pyInput', pyInput)

      // 拼音首字母
      const headerPyInput = pinyin(inputValue, { pattern: 'first', type: 'array' }).join('')
      console.log('headerPyInput', headerPyInput)

      return totalList.filter(e => {
        // 列表中每项的拼音
        const pyE = pinyin(e.province, { toneType: 'none', type: 'array' }).join('').slice(0, pyInput.length)
        console.log('pyE', pyE)

        // 列表中每项的拼音首字母
        const headerPyE = pinyin(e.province, { pattern: 'first', type: 'array' }).join('').slice(0, headerPyInput.length)
        console.log('headerPyE', headerPyE)
        console.log('_____________________')

        // 过滤匹配
        return e.province.includes(inputValue) || (pyE === pyInput) || (headerPyE === headerPyInput)
      })
    },
复制代码

3.调用方法

笔者使用的是vue,所以在数据的调用前加了this.

this.provinceList = this.pinyinFilter(this.inputProvince, this.totalProvinceList)

 

posted @   fnasklf  阅读(423)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
点击右上角即可分享
微信分享提示