av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

Vue文本模糊匹配功能如何實現

瀏覽:110日期:2022-12-21 18:09:51

模糊匹配功能在下拉菜單的組件中用的非常多,于是打算寫幾個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='http://www.4tl426be.cn/bcjs/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='http://www.4tl426be.cn/bcjs/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組件。

最后,通過設置查詢條件來控制子組件的顯示與隱藏即可實現實時模糊搜索。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 亚洲一区av | 一区二区不卡视频 | www婷婷| 一区二区在线看 | 欧美一级精品 | 欧美精品一区在线观看 | 在线观看免费毛片 | 日韩黄色免费视频 | 久久精选视频 | 五月婷婷六月丁香 | 丝袜美腿一区二区三区 | 极品尤物一区二区三区 | 国产精品一区av | 免费一区二区三区 | 国产香蕉av | 人人草人人爱 | 夜夜操网站 | 日韩免费在线观看 | 国产黄a三级三级三级看三级男男 | 日韩亚洲在线 | 成人免费福利视频 | 国产欧美视频在线观看 | 成人福利视频在线观看 | 4虎最新网址 | 欧美精品综合 | 国产精品久久一区 | 在线观看日韩精品 | 日本在线看片 | 国产伦理一区二区 | 欧美成人精品一区二区三区在线看 | 一区二区免费视频 | 岛国精品在线播放 | 波多野结衣乳巨码无在线观看 | 国产精品高潮呻吟av | 亚洲欧美中文字幕 | 91黄色大片 | 亚洲欧美在线播放 | 日韩欧美在线一区 | 国产精品视频久久 | 日韩黄色片 | 日韩成人高清 |