vue实现查找
Vue 实现查找功能的方法
在 Vue 中实现查找功能可以通过多种方式,以下是几种常见的实现方法:
方法一:使用计算属性过滤数据
通过计算属性结合数组的 filter 方法,可以实现基于关键字的查找功能。定义一个计算属性,根据输入的关键字过滤原始数据。
<template>
<div>
<input v-model="searchQuery" placeholder="Search...">
<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>
方法二:使用 Vuex 管理搜索状态

如果应用状态较为复杂,可以使用 Vuex 来管理搜索逻辑。将搜索关键字和过滤逻辑放在 Vuex 的 store 中。
// store.js
export default new Vuex.Store({
state: {
searchQuery: '',
items: [
{ id: 1, name: 'Apple' },
{ id: 2, name: 'Banana' },
{ id: 3, name: 'Orange' }
]
},
getters: {
filteredItems(state) {
return state.items.filter(item =>
item.name.toLowerCase().includes(state.searchQuery.toLowerCase())
);
}
},
mutations: {
setSearchQuery(state, query) {
state.searchQuery = query;
}
}
});
// Component
<template>
<div>
<input v-model="searchQuery" @input="updateSearchQuery" placeholder="Search...">
<ul>
<li v-for="item in filteredItems" :key="item.id">
{{ item.name }}
</li>
</ul>
</div>
</template>
<script>
import { mapGetters, mapMutations } from 'vuex';
export default {
computed: {
...mapGetters(['filteredItems']),
searchQuery: {
get() {
return this.$store.state.searchQuery;
},
set(value) {
this.setSearchQuery(value);
}
}
},
methods: {
...mapMutations(['setSearchQuery'])
}
};
</script>
方法三:使用第三方库实现高级搜索

对于更复杂的搜索需求,可以借助第三方库如 Fuse.js 实现模糊搜索或全文检索。
<template>
<div>
<input v-model="searchQuery" placeholder="Search...">
<ul>
<li v-for="item in searchResults" :key="item.id">
{{ item.name }}
</li>
</ul>
</div>
</template>
<script>
import Fuse from 'fuse.js';
export default {
data() {
return {
searchQuery: '',
items: [
{ id: 1, name: 'Apple' },
{ id: 2, name: 'Banana' },
{ id: 3, name: 'Orange' }
],
fuse: null
};
},
created() {
this.fuse = new Fuse(this.items, {
keys: ['name'],
threshold: 0.3
});
},
computed: {
searchResults() {
if (!this.searchQuery) return this.items;
return this.fuse.search(this.searchQuery).map(result => result.item);
}
}
};
</script>
方法四:结合后端 API 实现搜索
如果数据量较大或需要实时性,可以通过调用后端 API 实现搜索功能。使用 axios 或其他 HTTP 客户端发送请求。
<template>
<div>
<input v-model="searchQuery" @input="debouncedSearch" placeholder="Search...">
<ul>
<li v-for="item in searchResults" :key="item.id">
{{ item.name }}
</li>
</ul>
</div>
</template>
<script>
import axios from 'axios';
import debounce from 'lodash.debounce';
export default {
data() {
return {
searchQuery: '',
searchResults: []
};
},
created() {
this.debouncedSearch = debounce(this.search, 300);
},
methods: {
search() {
if (!this.searchQuery) {
this.searchResults = [];
return;
}
axios.get('/api/search', { params: { q: this.searchQuery } })
.then(response => {
this.searchResults = response.data;
});
}
}
};
</script>
注意事项
- 对于大量数据的搜索,建议使用防抖(debounce)或节流(throttle)优化性能,避免频繁触发搜索逻辑。
- 如果搜索逻辑复杂,可以将其拆分为独立的函数或模块,便于维护和测试。
- 考虑用户体验,提供搜索结果的加载状态或空状态提示。






