首页 > 其他分享 >vue中利用pinyin-pro纯前端实现拼音的模糊搜索

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

时间:2022-11-22 16:55:17浏览次数:76  
标签:vue pyInput 拼音 pinyin pro headerPyInput console

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)

 

标签:vue,pyInput,拼音,pinyin,pro,headerPyInput,console
From: https://www.cnblogs.com/p201821460026/p/16915655.html

相关文章

  • Android开发 内容提供者ContentProvider
    前言ContentProvider内容提供者属于Android四大组件之一,是用来让App将一些共享数据提供给外部操作的组件。一般情况下是配合数据库使用,将数据库内容外露给外部进行增......
  • Profinet总线模块与西门子通信
    准备IO模块:耦合器BL200PN、数字量输出模块M2082、数字量输入M1081、模拟量输入模块M3401、模拟量输出M4043。2、BL200PN、S7-1200、PC要同一局域网。将BL200PN和......
  • Vue基础总结
    1、库和框架Vue是一个渐进式(逐步集成更多的功能)的javascript框架库:封装属性或方法框架:拥有自己的规则和元素,比库强大的多Vue开发模式:传统&工程化开发方式(基于webpack,推......
  • vue-ref,reactive,toRefs,toRef总结
    总结:ref,reactive,toRefs,toRef方法响应式引用的原理:通过proxy对数据进行封装,当数据变化时,触发模版等内容的更新。一、ref:作用:接受一个内部值并返回响应式且可变的ref对象......
  • 1、5分钟带你入门vuex(vuex状态管理)
    如果你之前使用过vue.js,你一定知道在vue中各个组件之间传值的痛苦,在vue中我们可以使用vuex来保存我们需要管理的状态值,值一旦被修改,所有引用该值的地方就会自动更新,那么接......
  • Full Activation V1.36 V1.35 Orange5 Orange 5 Super Pro Professional Programming
    Orange5SuperPro,Orange5superproprogrammer Orange5superproprogrammerisaprofessionalprogrammingdeviceformemoryandmicrocontrollers.Unique......
  • vue2 计算属性10
    计算属性:可以在差值模板或者methods属性等地方用案例:使用v-model双向绑定值 或       ......
  • Qt中的.pro文件
    .pro就是工程文件(project),它是qmake自动生成的用于生产makefile的配置文件。.pro文件的写法如下:注释从“#”开始,到这一行结束。模板变量告诉qmake为这个应用程序生成哪种ma......
  • Vue 中const 命令 
    const命令请记得const和let都是块级作用域,var是函数级作用域//constandletonlyexistintheblockstheyaredefinedin.{leta=1constb=1}console.lo......
  • kube-prometheus安装部署
    引言本文主要讲解在k8s(kubernetes)下安装kube-prometheus。kube-prometheus的github地址:https://github.com/prometheus-operator/kube-prometheuskube-promethues本质......