Vue文本模糊匹配功能如何实现


Posted in Javascript onJuly 30, 2020

模糊匹配功能在下拉菜单的组件中用的非常多,于是打算写几个demo看看细节上是如何实现的。

一、最简单的模糊匹配:计算属性

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>
<body>
  <div id="app">
    <input type="text" v-model="message">
    <ul>
      <li v-for="(option, index) in matchedOptions" :key="index">{{ option }}</li>
    </ul>
  </div>
  <script src="./vue.js"></script>
  <script>
    new Vue({
      el: '#app',
      data: {
        message: '',
        options: ['html', 'css', 'javascript']
      },
      computed: {
        matchedOptions() {
          if (this.message !== '') {
            return this.options.filter(option => option.includes(this.message))
          }
          return this.options
        }
      }
    })
  </script>
</body>
</html>

在上面的例子中,计算属性matchedOptions会在文本框内容message变化时筛选options里的数据,效果图如下所示:

Vue文本模糊匹配功能如何实现

二、使用作用域插槽实现

使用插槽主要是为了使该功能组件化:在select组件中插入option,然后option通过作用域插槽从select中获取文本值:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>
<body>
  <div id="app">
    <my-select>
      <template #default="{ message }">
        <ul>
          <li v-for="(option, index) in options" :key="index" v-show="option.includes(message)">{{ option }}</li>
        </ul>
      </template>
    </my-select>
  </div>
  <script src="./vue.js"></script>
  <script>
    Vue.component('my-select', {
      template: `
        <div class="my-select">
          <input type="text" v-model="message">
          <slot :message="message"></slot>
        </div>
      `,
      data() {
        return {
          message: ''
        }
      }
    })
    new Vue({
      el: '#app',
      data: {
        options: ['html', 'css', 'javascript']
      }
    })
  </script>
</body>
</html>

全局注册了my-select组件后,可以删除app里的message数据,使用v-show来控制选项的显示,运行效果和计算属性方式相同。缺点就是无法单文件化(刚学vue没多久,不知道怎么在单文件里使用作用域插槽,试过直接把template里的东西封装成my-option好像并不管用)

三、混入广播和派发方法在独立组件中实现模糊匹配

首先需要一个emitter文件:

/**
 * 子组件广播事件
 * @param {string} componentName 子组件名
 * @param {string} eventName 事件名
 * @param {...any} params 事件参数
 */
function _broadcast(componentName, eventName, ...params) {
  this.$children.forEach(child => {
    if (child.$options.name === componentName) {
      child.$emit(eventName, ...params)
    }
    _broadcast.call(child, componentName, eventName, ...params)
  })
}

/**
 * 父组件派发事件
 * @param {string} componentName 父组件名
 * @param {string} eventName 事件名
 * @param {...any} params 事件参数
 */
function _dispatch(componentName, eventName, ...params) {
  if (this.$parent) {
    if (this.$parent.$options.name === componentName) {
      this.$parent.$emit(eventName, ...params)
    }
    _dispatch.call(this.$parent, componentName, eventName, ...params)
  }
}

/**
 * mixin
 */
export default {
  methods: {
    broadcast(componentName, eventName, ...params) {
      _broadcast.call(this, componentName, eventName, ...params)
    },
    dispatch(componentName, eventName, ...params) {
      _dispatch.call(this, componentName, eventName, ...params)
    }
  }
}

注意,这里的$children和$parent都是指具有dom父子关系的vue组件。

最后,通过设置查询条件来控制子组件的显示与隐藏即可实现实时模糊搜索。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery与其它库冲突的解决方法
Jun 25 Javascript
妙用Jquery的val()方法
Jun 27 Javascript
两个多选select(multiple左右)添加、删除选项和取值实例
May 12 Javascript
js中匿名函数的创建与调用方法分析
Dec 19 Javascript
js完美实现@提到好友特效(兼容各大浏览器)
Mar 16 Javascript
JavaScript中for循环的使用详解
Jun 03 Javascript
纯javascript移动优先的幻灯片效果
Nov 02 Javascript
深入理解vue.js中的v-if和v-show
Jun 22 Javascript
详解angularJS+Ionic移动端图片上传的解决办法
Sep 13 Javascript
vue router 通过路由来实现切换头部标题功能
Apr 24 Javascript
JavaScript中工厂函数与构造函数示例详解
May 06 Javascript
详解js根据百度地图提供经纬度计算两点距离
May 13 Javascript
VUE 单页面使用 echart 窗口变化时的用法
Jul 30 #Javascript
解决vue单页面多个组件嵌套监听浏览器窗口变化问题
Jul 30 #Javascript
Vue Render函数原理及代码实例解析
Jul 30 #Javascript
vue - props 声明数组和对象操作
Jul 30 #Javascript
vue项目,代码提交至码云,iconfont的用法说明
Jul 30 #Javascript
vue如何使用外部特殊字体的操作
Jul 30 #Javascript
在vue-cli3中使用axios获取本地json操作
Jul 30 #Javascript
You might like
造势之举?韩国总统候选人发布《星际争霸》地图
2017/04/22 星际争霸
CodeIgniter php mvc框架 中国网站
2008/05/26 PHP
php数组函数序列之array_unique() - 去除数组中重复的元素值
2011/10/29 PHP
php格式输出文件var_export函数实例
2014/11/15 PHP
php最简单的删除目录与文件实现方法
2014/11/28 PHP
Windows2003下php5.4安装配置教程(IIS)
2016/06/30 PHP
基于thinkPHP实现的微信自定义分享功能示例
2016/09/23 PHP
利用PHP_XLSXWriter代替PHPExcel的方法示例
2017/07/16 PHP
laravel实现登录时监听事件,添加登录用户的记录方法
2019/09/30 PHP
Yii框架的redis命令使用方法简单示例
2019/10/15 PHP
在 PHP 和 Laravel 中使用 Traits的方法
2019/11/13 PHP
Laravel5.1 框架数据库操作DB运行原生SQL的方法分析
2020/01/07 PHP
用JQuery在网页中实现分隔条功能的代码
2012/08/09 Javascript
理解js回收机制通俗易懂版
2016/02/29 Javascript
JavaScript常用字符串与数组扩展函数小结
2016/04/24 Javascript
解决微信浏览器Javascript无法使用window.location.reload()刷新页面
2016/06/21 Javascript
最基础的vue.js双向绑定操作
2017/08/23 Javascript
ionic+html5+API实现双击返回键退出应用
2019/09/17 Javascript
JS hasOwnProperty()方法检测一个属性是否是对象的自有属性的方法
2021/01/29 Javascript
Python实现简单的可逆加密程序实例
2015/03/05 Python
编写Python CGI脚本的教程
2015/06/29 Python
学习python 之编写简单乘法运算题
2016/02/27 Python
Python实现文件内容批量追加的方法示例
2017/08/29 Python
基于Python pip用国内镜像下载的方法
2018/06/12 Python
详解pandas安装若干异常及解决方案总结
2019/01/10 Python
python 对类的成员函数开启线程的方法
2019/01/22 Python
Django项目使用CircleCI的方法示例
2019/07/14 Python
python实现发送form-data数据的方法详解
2019/09/27 Python
python3实现单目标粒子群算法
2019/11/14 Python
西班牙太阳镜品牌:Hawkers
2018/03/11 全球购物
森林防火宣传标语
2014/06/27 职场文书
西安事变观后感
2015/06/12 职场文书
致运动员赞词
2015/07/22 职场文书
工程主管竞聘书
2015/09/15 职场文书
PHP正则表达式之RCEService回溯
2022/04/11 PHP
Golang ort 中的sortInts 方法
2022/04/24 Golang