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

模糊匹配功能在下拉菜单的组件中用的非常多,于是打算写几个demo看看细节上是如何实现的。一、最简单的模糊匹配:计算属性<!D

模糊匹配功能在下拉菜单的组件中用的非常多,于是打算写几个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=”https://www.wpmee.com/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里的数据,效果图如下所示:

WordPress主题下载,WordPress免费主题下载,网站源码模板下载

二、使用作用域插槽实现

使用插槽主要是为了使该功能组件化:在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=”https://www.wpmee.com/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组件。

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

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

WordPress主题下载,WordPress免费主题下载,网站源码模板下载


下载说明:
1. 本站所有资源来源于网络和用户上传,如有侵权请联系站长
2. 本站分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,商用请支持正版!不得违反国家法律,否则后果自负!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!

本站的资源均来自于互联网,仅为资源共享、学习参考之目的,其版权均归原作者及其网站所有,如有侵权请留言联系:admin,转转请注明出处:http://zhanmr.com/7016.htm

发表评论

电子邮件地址不会被公开。 必填项已用*标注