vue实现实时搜索
实现实时搜索的基本思路
在Vue中实现实时搜索功能通常需要结合v-model指令监听输入框的变化,并通过防抖(debounce)技术优化性能。以下是具体实现方法:
基础实现方式
创建Vue组件,使用v-model绑定输入框的值:
<template>
<div>
<input
type="text"
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: '苹果' },
{ id: 2, name: '香蕉' },
{ id: 3, name: '橙子' }
]
}
},
computed: {
filteredItems() {
return this.items.filter(item =>
item.name.toLowerCase().includes(this.searchQuery.toLowerCase())
)
}
}
}
</script>
添加防抖优化
频繁触发搜索会影响性能,使用lodash.debounce优化:
<script>
import debounce from 'lodash.debounce'
export default {
data() {
return {
searchQuery: '',
filteredItems: []
}
},
created() {
this.debouncedSearch = debounce(this.doSearch, 300)
},
methods: {
doSearch() {
// 这里替换为实际API调用或本地过滤逻辑
this.filteredItems = this.items.filter(item =>
item.name.toLowerCase().includes(this.searchQuery.toLowerCase())
)
}
},
watch: {
searchQuery() {
this.debouncedSearch()
}
}
}
</script>
结合API请求
当需要从后端获取搜索结果时:
methods: {
async doSearch() {
try {
const response = await axios.get('/api/search', {
params: { q: this.searchQuery }
})
this.filteredItems = response.data
} catch (error) {
console.error('搜索出错:', error)
}
}
}
使用自定义指令实现防抖
也可以创建自定义防抖指令:
Vue.directive('debounce', {
inserted(el, binding) {
let debounceTimeout
el.addEventListener('input', () => {
clearTimeout(debounceTimeout)
debounceTimeout = setTimeout(() => {
binding.value()
}, 300)
})
}
})
使用方法:
<input v-debounce="doSearch" v-model="searchQuery">
注意事项
- 移动端需要额外处理虚拟键盘的显示/隐藏事件
- 网络请求需要考虑取消机制,避免旧请求影响最新结果
- 空搜索查询时可以考虑显示默认内容或最近搜索记录
- 对于大量本地数据,建议使用Web Worker进行过滤计算







