Vue文本模糊匹配功能如何實(shí)現(xiàn)
模糊匹配功能在下拉菜單的組件中用的非常多,于是打算寫幾個(gè)demo看看細(xì)節(jié)上是如何實(shí)現(xiàn)的。
一、最簡(jiǎn)單的模糊匹配:計(jì)算屬性
<!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>
在上面的例子中,計(jì)算屬性matchedOptions會(huì)在文本框內(nèi)容message變化時(shí)篩選options里的數(shù)據(jù),效果圖如下所示:
二、使用作用域插槽實(shí)現(xiàn)
使用插槽主要是為了使該功能組件化:在select組件中插入option,然后option通過(guò)作用域插槽從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>
全局注冊(cè)了my-select組件后,可以刪除app里的message數(shù)據(jù),使用v-show來(lái)控制選項(xiàng)的顯示,運(yùn)行效果和計(jì)算屬性方式相同。缺點(diǎn)就是無(wú)法單文件化(剛學(xué)vue沒(méi)多久,不知道怎么在單文件里使用作用域插槽,試過(guò)直接把template里的東西封裝成my-option好像并不管用)
三、混入廣播和派發(fā)方法在獨(dú)立組件中實(shí)現(xiàn)模糊匹配
首先需要一個(gè)emitter文件:
/** * 子組件廣播事件 * @param {string} componentName 子組件名 * @param {string} eventName 事件名 * @param {...any} params 事件參數(shù) */ function _broadcast(componentName, eventName, ...params) { this.$children.forEach(child => { if (child.$options.name === componentName) { child.$emit(eventName, ...params) } _broadcast.call(child, componentName, eventName, ...params) }) } /** * 父組件派發(fā)事件 * @param {string} componentName 父組件名 * @param {string} eventName 事件名 * @param {...any} params 事件參數(shù) */ 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父子關(guān)系的vue組件。
最后,通過(guò)設(shè)置查詢條件來(lái)控制子組件的顯示與隱藏即可實(shí)現(xiàn)實(shí)時(shí)模糊搜索。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue實(shí)現(xiàn)進(jìn)入全屏和退出全屏的示例代碼
最近一個(gè)項(xiàng)目需要進(jìn)行大屏展示,所以登錄完就要處于一個(gè)全屏的狀態(tài),本文主要介紹了vue實(shí)現(xiàn)進(jìn)入全屏和退出全屏的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下2023-12-12Vue中router-view和component :is的區(qū)別解析
這篇文章主要介紹了Vue中router-view和component :is的區(qū)別解析,router-view用法直接填寫跳轉(zhuǎn)路由,路由組件會(huì)渲染<router-view></router-view>標(biāo)簽,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10Vue中使用iframe踩坑問(wèn)題記錄 iframe+postMessage
這篇文章主要介紹了Vue中使用iframe踩坑問(wèn)題記錄 iframe+postMessage,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09vue+iview+less 實(shí)現(xiàn)換膚功能
這篇文章主要介紹了vue+iview+less 實(shí)現(xiàn)換膚功能,項(xiàng)目搭建用的vue—cli,css框架選擇的iview,具體操作流程大家跟隨腳本之家小編一起看看吧2018-08-08vue-cli3 DllPlugin 提取公用庫(kù)的方法
這篇文章主要介紹了vue-cli3 DllPlugin 提取公用庫(kù) ,需要的朋友可以參考下2019-04-04Vue+ElementUI前端添加展開(kāi)收起搜索框按鈕完整示例
最近一直在用element ui做后臺(tái)項(xiàng)目,下面這篇文章主要給大家介紹了關(guān)于Vue+ElementUI前端添加展開(kāi)收起搜索框按鈕的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-05-05