欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中輕量級(jí)模糊查詢fuse.js使用方法步驟

 更新時(shí)間:2024年01月15日 15:21:46   作者:離逝的楓  
這篇文章主要給大家介紹了關(guān)于vue中輕量級(jí)模糊查詢fuse.js使用方法的相關(guān)資料,Fuse.js是一個(gè)功能強(qiáng)大、輕量級(jí)的模糊搜索庫(kù),通過提供簡(jiǎn)單的?api?調(diào)用,達(dá)到強(qiáng)大的模糊搜索效果,需要的朋友可以參考下

前言

由于本樣例是基于vue3中來實(shí)現(xiàn)的,fuse是一個(gè)前端自行進(jìn)行模糊查詢的相關(guān)插件,常用于系統(tǒng)路由菜單的相關(guān)搜索等數(shù)據(jù)量不太大的情況,若需要數(shù)據(jù)量很大,還是蠻建議通過后端返回?cái)?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)配置項(xiàng)的說明

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

3.fuse的實(shí)際運(yùn)用

3.1 具體代碼

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

其實(shí)fuse中比較重要的就兩個(gè)配置,這兩個(gè)配置如下

一個(gè)初始化fuse

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

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

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

search_all.value = [
  {
    title: "Java虛擬機(jī)",
    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ù)可以和后臺(tái)返回的數(shù)據(jù)進(jìn)行結(jié)核,形成遠(yuǎn)程搜索 
search_all.value = [
  {
    title: "Java虛擬機(jī)",
    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ù)對(duì)結(jié)果列表排序
    threshold: 0.4,    //匹配算法閾值。閾值為0.0需要完全匹配(字母和位置),閾值為1.0將匹配任何內(nèi)容。
    location: 0,    // 確定文本中預(yù)期找到的模式的大致位置。
    distance: 100,
    minMatchCharLength: 1, // 模式的最大長(zhǎng)度
    //搜索標(biāo)題與作者名
    keys: [{
      name: 'title',
      weight: 0.7    //設(shè)置權(quán)重
    }, {
      name: 'author.firstName',
      weight: 0.3    //設(shè)置權(quán)重
    }]
  })
}
//也可以將這個(gè)放在created生命周期,這里使用了setup語法糖
init_search(search_all.value)
</script>

總結(jié) 

到此這篇關(guān)于vue中輕量級(jí)模糊查詢fuse.js使用的文章就介紹到這了,更多相關(guān)vue使用輕量級(jí)模糊查詢fuse.js內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 一文搞懂Vue中watch偵聽器的用法

    一文搞懂Vue中watch偵聽器的用法

    在Vue.js中,您可以使用watch選項(xiàng)來創(chuàng)建偵聽器,以偵聽特定屬性的變化,偵聽器可以在屬性發(fā)生變化時(shí)執(zhí)行相關(guān)的邏輯,本文給大家詳細(xì)講講Vue中watch偵聽器的用法,需要的朋友可以參考下
    2023-11-11
  • 詳解vue-router 命名路由和命名視圖

    詳解vue-router 命名路由和命名視圖

    這篇文章主要介紹了詳解vue-router 命名路由和命名視圖,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06
  • 詳解使用vue實(shí)現(xiàn)tab 切換操作

    詳解使用vue實(shí)現(xiàn)tab 切換操作

    這篇文章主要介紹了詳解使用vue實(shí)現(xiàn)tab操作,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-07-07
  • Vue2安裝使用MonacoEditor方式(自定義語法,自定義高亮,自定義提示)

    Vue2安裝使用MonacoEditor方式(自定義語法,自定義高亮,自定義提示)

    這篇文章主要介紹了Vue2安裝使用MonacoEditor方式(自定義語法,自定義高亮,自定義提示),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue使用axios導(dǎo)出后臺(tái)返回的文件流為excel表格詳解

    vue使用axios導(dǎo)出后臺(tái)返回的文件流為excel表格詳解

    這篇文章主要介紹了vue使用axios導(dǎo)出后臺(tái)返回的文件流為excel表格方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue實(shí)現(xiàn)高德坐標(biāo)轉(zhuǎn)GPS坐標(biāo)功能的示例詳解

    Vue實(shí)現(xiàn)高德坐標(biāo)轉(zhuǎn)GPS坐標(biāo)功能的示例詳解

    生活中常用的幾種坐標(biāo)有:WGS-84、GCJ-02與BD-09。本文將利用Vue實(shí)現(xiàn)高德坐標(biāo)轉(zhuǎn)GPS坐標(biāo)功能,即實(shí)現(xiàn)GCJ-02坐標(biāo)轉(zhuǎn)換成WGS-84坐標(biāo),需要的可以參考一下
    2022-04-04
  • vue-element-admin開發(fā)教程(v4.0.0之后)

    vue-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 綁定單個(gè)或多個(gè) Class 名的實(shí)例代碼

    使用 Vue 綁定單個(gè)或多個(gè) Class 名的實(shí)例代碼

    這篇文章主要介紹了使用 Vue 綁定單個(gè)或多個(gè) Class 名的實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2018-01-01
  • vue3.0中sass全局的使用過程

    vue3.0中sass全局的使用過程

    這篇文章主要介紹了vue3.0中sass全局的使用過程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • @vue/cli4.x版本的vue.config.js常用配置方式

    @vue/cli4.x版本的vue.config.js常用配置方式

    這篇文章主要介紹了@vue/cli4.x版本的vue.config.js常用配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05

最新評(píng)論