当前位置:首页 > VUE

vue前端实现模糊查询

2026-02-20 21:11:51VUE

Vue 前端实现模糊查询的方法

使用 JavaScript 的 filterincludes 方法

在 Vue 中,可以通过计算属性或方法对数组进行过滤,结合 includes 方法实现模糊查询。

<template>
  <div>
    <input v-model="searchQuery" placeholder="搜索...">
    <ul>
      <li v-for="item in filteredItems" :key="item.id">
        {{ item.name }}
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      searchQuery: '',
      items: [
        { id: 1, name: 'Apple' },
        { id: 2, name: 'Banana' },
        { id: 3, name: 'Orange' }
      ]
    }
  },
  computed: {
    filteredItems() {
      return this.items.filter(item => 
        item.name.toLowerCase().includes(this.searchQuery.toLowerCase())
      )
    }
  }
}
</script>

使用正则表达式实现更灵活的匹配

如果需要更复杂的模糊匹配,可以使用正则表达式。

vue前端实现模糊查询

computed: {
  filteredItems() {
    const query = this.searchQuery.toLowerCase()
    const regex = new RegExp(query, 'i')
    return this.items.filter(item => regex.test(item.name))
  }
}

结合 Lodash 的 debounce 优化性能

频繁输入时,可以使用 Lodash 的 debounce 函数减少计算频率,提升性能。

vue前端实现模糊查询

import { debounce } from 'lodash'

export default {
  data() {
    return {
      searchQuery: '',
      filteredItems: []
    }
  },
  watch: {
    searchQuery: debounce(function(newVal) {
      this.filteredItems = this.items.filter(item => 
        item.name.toLowerCase().includes(newVal.toLowerCase())
      )
    }, 300)
  }
}

使用第三方库 Fuse.js 实现高级模糊搜索

Fuse.js 是一个强大的模糊搜索库,支持更复杂的匹配逻辑。

import Fuse from 'fuse.js'

export default {
  data() {
    return {
      searchQuery: '',
      fuse: null,
      items: [
        { id: 1, name: 'Apple' },
        { id: 2, name: 'Banana' },
        { id: 3, name: 'Orange' }
      ]
    }
  },
  created() {
    this.fuse = new Fuse(this.items, {
      keys: ['name'],
      threshold: 0.3
    })
  },
  computed: {
    filteredItems() {
      return this.searchQuery 
        ? this.fuse.search(this.searchQuery).map(result => result.item)
        : this.items
    }
  }
}

结合 Vuex 实现全局搜索

如果项目使用 Vuex,可以将搜索逻辑放在 store 中统一管理。

// store.js
const store = new Vuex.Store({
  state: {
    items: [
      { id: 1, name: 'Apple' },
      { id: 2, name: 'Banana' },
      { id: 3, name: 'Orange' }
    ],
    searchQuery: ''
  },
  getters: {
    filteredItems: state => {
      return state.items.filter(item => 
        item.name.toLowerCase().includes(state.searchQuery.toLowerCase())
      )
    }
  }
})

以上方法可以根据项目需求选择使用,从简单到复杂逐步扩展功能。

标签: 模糊vue
分享给朋友:

相关文章

vue实现下载暂停

vue实现下载暂停

Vue实现下载暂停功能 在Vue中实现下载暂停功能,通常需要结合XMLHttpRequest或Fetch API的AbortController来控制请求中断。以下是具体实现方法: 使用XMLHtt…

vue实现拍照

vue实现拍照

Vue实现拍照功能 在Vue中实现拍照功能通常需要结合浏览器的MediaDevices API和Canvas元素。以下是具体实现方法: 安装依赖(可选) 如果需要更简单的封装,可以安装vue-web…

vue的实现

vue的实现

Vue 的实现原理 Vue 是一个渐进式 JavaScript 框架,其核心实现主要包括响应式系统、虚拟 DOM、模板编译和组件化机制。以下是 Vue 实现的主要技术细节。 响应式系统 Vue 的响…

分页实现vue

分页实现vue

分页实现(Vue) 在Vue中实现分页功能通常需要结合前端分页逻辑和后端API支持。以下是两种常见的实现方式: 前端分页实现 适用于数据量较小的情况,直接在客户端完成分页逻辑。 <templ…

vue实现slidetoggle

vue实现slidetoggle

Vue 实现 SlideToggle 效果 SlideToggle 是一种常见的交互效果,元素以滑动方式展开或收起。以下是几种实现方法: 使用 CSS Transition 和 v-show 通过…

vue实现微云

vue实现微云

Vue 实现微云功能 使用 Vue 实现类似微云的网盘功能需要结合前端框架、后端存储及文件处理技术。以下是关键实现步骤和代码示例: 前端框架搭建 使用 Vue CLI 创建项目基础结构,安装必要依赖…