vue中輕量級模糊查詢fuse.js使用方法步驟
前言
由于本樣例是基于vue3中來實現(xià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)于是多余的,就類似于遠(yuǎn)程搜索。那么就會有人問,問什么循環(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-option remote 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)配置項,就是我們目標(biāo)數(shù)據(jù)list中的相關(guān)參數(shù)
//初始化搜索引擎 const init_search = (list) => { fuse.value = new Fuse(list, { shouldSort: true, //是否按分?jǐn)?shù)對結(jié)果列表排序 threshold: 0.4, //匹配算法閾值。閾值為0.0需要完全匹配(字母和位置),閾值為1.0將匹配任何內(nèi)容。 location: 0, // 確定文本中預(yù)期找到的模式的大致位置。 distance: 100, minMatchCharLength: 1, // 模式的最大長度 //搜索標(biāo)題與作者名 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-option remote 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é)核,形成遠(yuǎn)程搜索 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, //是否按分?jǐn)?shù)對結(jié)果列表排序 threshold: 0.4, //匹配算法閾值。閾值為0.0需要完全匹配(字母和位置),閾值為1.0將匹配任何內(nèi)容。 location: 0, // 確定文本中預(yù)期找到的模式的大致位置。 distance: 100, minMatchCharLength: 1, // 模式的最大長度 //搜索標(biāo)題與作者名 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>
總結(jié)
到此這篇關(guān)于vue中輕量級模糊查詢fuse.js使用的文章就介紹到這了,更多相關(guān)vue使用輕量級模糊查詢fuse.js內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Avue實現(xiàn)動態(tài)查詢與數(shù)據(jù)展示的示例代碼
- vue中el表單的簡單查詢方法
- 5種vue模糊查詢的方法總結(jié)
- vue+element?ui表格添加多個搜索條件篩選功能(前端查詢)
- vue中wangEditor的使用及回顯數(shù)據(jù)獲取焦點的方法
- Vue前端如何實現(xiàn)與后端進行數(shù)據(jù)交互
- vue.js前后端數(shù)據(jù)交互之提交數(shù)據(jù)操作詳解
- 詳解vue與后端數(shù)據(jù)交互(ajax):vue-resource
- Vue?3?表單與后端數(shù)據(jù)交互之查詢并回顯數(shù)據(jù)步驟流程
相關(guān)文章
Vue2安裝使用MonacoEditor方式(自定義語法,自定義高亮,自定義提示)
這篇文章主要介紹了Vue2安裝使用MonacoEditor方式(自定義語法,自定義高亮,自定義提示),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04vue使用axios導(dǎo)出后臺返回的文件流為excel表格詳解
這篇文章主要介紹了vue使用axios導(dǎo)出后臺返回的文件流為excel表格方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08Vue實現(xiàn)高德坐標(biāo)轉(zhuǎn)GPS坐標(biāo)功能的示例詳解
生活中常用的幾種坐標(biāo)有:WGS-84、GCJ-02與BD-09。本文將利用Vue實現(xiàn)高德坐標(biāo)轉(zhuǎn)GPS坐標(biāo)功能,即實現(xiàn)GCJ-02坐標(biāo)轉(zhuǎn)換成WGS-84坐標(biāo),需要的可以參考一下2022-04-04vue-element-admin開發(fā)教程(v4.0.0之后)
由于vue-element-admin的架構(gòu)再4.0.0版本后做了重構(gòu),整體結(jié)構(gòu)上和之前的還是很相似的,但是也有些變化,本文就介紹vue-element-admin開發(fā)教程(v4.0.0之后),感興趣的可以了解一下2022-04-04@vue/cli4.x版本的vue.config.js常用配置方式
這篇文章主要介紹了@vue/cli4.x版本的vue.config.js常用配置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05