日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > vue >内容正文

vue

vue中轻量级模糊查询fuse.js使用

發(fā)布時間:2023/12/20 vue 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vue中轻量级模糊查询fuse.js使用 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

由于本樣例是基于vue3中來實現(xiàn)的,若你使用的是vue2,請在評論區(qū)中發(fā)表后,也會出vue2中的相關(guān)使用。fuse是一個前端自行進行模糊查詢的相關(guān)插件,常用于系統(tǒng)路由菜單的相關(guān)搜索等數(shù)據(jù)量不太大的情況,若需要數(shù)據(jù)量很大,還是蠻建議通過后端返回數(shù)據(jù)的相關(guān)形式。

1.安裝fuse.js

1.1如下是相關(guān)的引用和安裝,我們可以發(fā)現(xiàn)這種的引入后,就只占用15.8K的大小

npm install fuse.js import Fuse from 'fuse.js'

2.fuse相關(guān)配置項的說明

2.1下面是fuse中的一些配置項的相關(guān)說明,但在實際運用的時候,其中的某些配置項比較重要

3.fuse的實際運用

3.1 具體代碼

這里我們是基于elementplus中的el-select組件來進行運用的,因為在這個組件中會有一個方法,remote-method就是在我們搜索之前會執(zhí)行,此時就不需要在通過watch來監(jiān)聽search是否發(fā)生改變因此這里的v-model就相當(dāng)于是多余的,就類似于遠程搜索。那么就會有人問,問什么循環(huán)中是option.item.title呢?那是因為通過fuse模糊查詢出來的數(shù)據(jù)是被封裝到一個一個的item中了。

<template><div class="hello"><el-select ref="headerSearchSelect" v-model="search" :remote-method="querySearch" filterable default-first-optionremote placeholder="Search" class="header-search-select" @change="change"><el-option v-for="option in search_result" :key="option.item.title" :value="option.item.title":label="option.item.author.firstName" /></el-select></div> </template>

其實fuse中比較重要的就兩個配置,這兩個配置如下

一個初始化fuse

其中的keys中的相關(guān)配置項,就是我們目標數(shù)據(jù)list中的相關(guān)參數(shù)

//初始化搜索引擎 const init_search = (list) => {fuse.value = new Fuse(list, {shouldSort: true, //是否按分數(shù)對結(jié)果列表排序threshold: 0.4, //匹配算法閾值。閾值為0.0需要完全匹配(字母和位置),閾值為1.0將匹配任何內(nèi)容。location: 0, // 確定文本中預(yù)期找到的模式的大致位置。distance: 100,minMatchCharLength: 1, // 模式的最大長度//搜索標題與作者名keys: [{name: 'title',weight: 0.7 //設(shè)置權(quán)重}, {name: 'author.firstName',weight: 0.3 //設(shè)置權(quán)重}]}) }

一個是相關(guān)列表

search_all.value = [{title: "Java虛擬機",author: {firstName: "王浩",lastName: "wanghao"}},{title: "人工智能",author: {firstName: "侯建軍",lastName: "marquis"}} ]

具體結(jié)果

4.完整代碼

<template><div class="hello"><el-select ref="headerSearchSelect" v-model="search" :remote-method="querySearch" filterable default-first-optionremote placeholder="Search" class="header-search-select" @change="change"><el-option v-for="option in search_result" :key="option.item.title" :value="option.item.title":label="option.item.author.firstName" /></el-select></div> </template><script setup name="HelloWorld"> import { ref } from '@vue/reactivity' import Fuse from 'fuse.js'const fuse = ref(undefined)//待全文搜索的全部數(shù)據(jù) const search_all = ref([]) //搜索的結(jié)果 const search_result = ref([]) //后面的value的數(shù)據(jù)可以和后臺返回的數(shù)據(jù)進行結(jié)核,形成遠程搜索 search_all.value = [{title: "Java虛擬機",author: {firstName: "王浩",lastName: "wanghao"}},{title: "人工智能",author: {firstName: "侯建軍",lastName: "marquis"}} ] //搜索前出發(fā) const querySearch = (search_value) =>{if(search_value === ''){search_result.value = []}else{search_result.value = fuse.value.search(search_value)console.log( search_result.value);} }//初始化搜索引擎 const init_search = (list) => {fuse.value = new Fuse(list, {shouldSort: true, //是否按分數(shù)對結(jié)果列表排序threshold: 0.4, //匹配算法閾值。閾值為0.0需要完全匹配(字母和位置),閾值為1.0將匹配任何內(nèi)容。location: 0, // 確定文本中預(yù)期找到的模式的大致位置。distance: 100,minMatchCharLength: 1, // 模式的最大長度//搜索標題與作者名keys: [{name: 'title',weight: 0.7 //設(shè)置權(quán)重}, {name: 'author.firstName',weight: 0.3 //設(shè)置權(quán)重}]}) } //也可以將這個放在created生命周期,這里使用了setup語法糖 init_search(search_all.value) </script>

若此文章對你有相關(guān)幫助的話,請幫忙點個贊,若有其他疑問,歡迎在評論中發(fā)表,我們共同進步

總結(jié)

以上是生活随笔為你收集整理的vue中轻量级模糊查询fuse.js使用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 三级黄片毛片 | 青青艹在线观看 | 黄色性生活一级片 | 亚洲综合久久婷婷 | 亚洲精品视频在线 | av丝袜在线 | 久久精品av| 亚洲专区中文字幕 | 无码成人一区二区 | 国产丝袜高跟 | 少妇4p| 日产av在线| 国产精品日韩在线观看 | 精品国产一区二区三区四区精华 | 中文字幕+乱码+中文乱码91 | 97超碰在线免费观看 | 精品91自产拍在线观看二区 | 99热热热热| 中文字幕一区二区三区四区视频 | 亚洲综合欧美 | 国内自拍一区 | 538精品一线 | 亚洲一区二区三区四 | 6680新视觉电影免费观看 | 成人听书哪个软件好 | 亚洲色成人www永久在线观看 | 少妇真人直播免费视频 | 一级黄色片a | 一区二区三区日韩电影 | 女优一区二区三区 | 在线观看视频色 | 日韩精品一区二区三区久久 | 播放黄色一级片 | 超碰在线人| 中文字幕不卡在线观看 | 人人做人人爽人人爱 | 3d动漫精品啪啪一区二区免费 | 欧美亚洲一区二区三区 | 欧美福利视频在线 | 亚洲av无码专区国产乱码不卡 | 日韩精品在线一区二区 | 天天爽夜夜爽夜夜爽 | 国产在线观看中文字幕 | 91视频久久久久 | 老司机亚洲精品 | 久久午夜场 | 久久久精品毛片 | 亚洲码欧美码一区二区三区 | 亚洲免费成人在线 | 九九免费在线视频 | 久久国产视频精品 | 久久久久久国产精品无码 | 国产精品999 | 欧美少妇15p | 国产男女猛烈无遮挡 | 九九综合视频 | 69黄色片| 亚洲成人手机在线 | 国产成人精品视频ⅴa片软件竹菊 | 亚洲日本中文字幕 | xxxxxx黄色| 国产视频福利在线观看 | 丰满熟妇乱又伦 | 日韩成人在线免费视频 | 制服丝袜一区 | 国产亚洲久久 | 久久99精品久久久久久噜噜 | 免费av网址在线 | 国产v综合v亚洲欧美久久 | 免费看a级黄色片 | 山外人精品影院 | 欧美日韩在线直播 | 999视频在线观看 | 91超级碰 | 伊人久久久久久久久久久 | 艳妇臀荡乳欲伦交换在线看 | 在线看片网址 | 天天做日日做 | av最新资源 | 女女爱爱视频 | 亚州av影院 | 国产精品久久中文字幕 | 欧美videos另类精品 | 欧美日韩一区二区不卡 | 国产在线不卡 | 熟女丰满老熟女熟妇 | 女人扒开腿免费视频app | 国产精品美女在线 | 成人免费看片网站 | 99这里精品 | 日韩黄色一区 | 色多多视频在线 | 每日更新在线观看av | 国产九一精品 | 风间由美av | 午夜激情在线观看视频 | www.色哟哟 | 上海贵妇尝试黑人洋吊 | 欧美黑人性猛交xxxx |