Vue3指令:搜索框输入防抖实现(附源码)

简介: Vue3指令:搜索框输入防抖实现(附源码)

在Vue3中,我们可以使用v-debounce指令来实现搜索框输入防抖。首先,我们需要安装一个名为lodash.debounce的库,然后创建一个自定义指令v-debounce

  1. 安装lodash.debounce库:
npm install lodash.debounce --save
  1. 创建一个自定义指令v-debounce
// 导入lodash库
import { debounce } from 'lodash';
// 创建一个自定义指令v-debounce
export default {
  // 注册指令
  directives: {
    debounce: {
      // 当指令绑定的元素被插入到DOM时执行
      inserted(el, binding) {
        // 获取用户传入的参数,例如延迟时间、事件处理函数等
        const { value = 300, arg = 'input' } = binding.value;
        // 使用lodash的debounce方法创建防抖函数
        const debouncedFn = debounce(binding.handler, value);
        // 将防抖函数赋值给元素的事件处理函数
        el.addEventListener(arg, debouncedFn);
      },
      // 当指令所在的组件被销毁时执行
      unbind(el) {
        // 移除元素上的事件监听器
        el.removeEventListener('input', el._v_debounce);
      }
    }
  }
};
  1. 在Vue组件中使用v-debounce指令:
<template>
  <div>
    <input type="text" v-model="searchText" v-debounce:input="handleSearch">
    <ul>
      <li v-for="item in filteredList" :key="item.id">{{ item.name }}</li>
    </ul>
  </div>
</template>
<script>
import vDebounce from './v-debounce'; // 导入自定义指令v-debounce
export default {
  name: 'SearchComponent',
  directives: {
    debounce: vDebounce // 注册自定义指令v-debounce
  },
  data() {
    return {
      searchText: '', // 搜索框中的文本
      list: [ // 原始数据列表,用于模拟搜索功能
        { id: 1, name: '苹果' },
        { id: 2, name: '香蕉' },
        { id: 3, name: '橙子' },
        { id: 4, name: '葡萄' }
      ]
    };
  },
  computed: {
    filteredList() { // 根据搜索文本过滤数据列表的方法
      return this.list.filter(item => item.name.includes(this.searchText));
    }
  },
  methods: {
    handleSearch() { // 搜索方法,根据过滤后的数据列表更新页面显示的内容
      console.log('搜索内容:', this.searchText); // 打印搜索内容到控制台,方便调试和查看效果
    }
  }
};
</script>

这样,我们就实现了一个基于Vue3的搜索框输入防抖功能。当用户在搜索框中输入时,会触发防抖函数,延迟一段时间后再执行搜索方法。这样可以有效减少搜索方法的执行次数,提高性能。

相关文章
|
1月前
|
JavaScript 前端开发 安全
Vue 3
Vue 3以组合式API、Proxy响应式系统和全面TypeScript支持,重构前端开发范式。性能优化与生态协同并进,兼顾易用性与工程化,引领Web开发迈向高效、可维护的新纪元。(238字)
487 139
|
1月前
|
缓存 JavaScript 算法
Vue 3性能优化
Vue 3 通过 Proxy 和编译优化提升性能,但仍需遵循最佳实践。合理使用 v-if、key、computed,避免深度监听,利用懒加载与虚拟列表,结合打包优化,方可充分发挥其性能优势。(239字)
201 1
|
2月前
|
开发工具 iOS开发 MacOS
基于Vite7.1+Vue3+Pinia3+ArcoDesign网页版webos后台模板
最新版研发vite7+vue3.5+pinia3+arco-design仿macos/windows风格网页版OS系统Vite-Vue3-WebOS。
362 11
|
1月前
|
JavaScript 安全
vue3使用ts传参教程
Vue 3结合TypeScript实现组件传参,提升类型安全与开发效率。涵盖Props、Emits、v-model双向绑定及useAttrs透传属性,建议明确声明类型,保障代码质量。
241 0
|
3月前
|
缓存 前端开发 大数据
虚拟列表在Vue3中的具体应用场景有哪些?
虚拟列表在 Vue3 中通过仅渲染可视区域内容,显著提升大数据列表性能,适用于 ERP 表格、聊天界面、社交媒体、阅读器、日历及树形结构等场景,结合 `vue-virtual-scroller` 等工具可实现高效滚动与交互体验。
420 1
|
JavaScript 前端开发
常用的vue指令语法用法
常用的vue指令语法用法
109 0
|
JavaScript 索引
vue指令作用以及用法
vue指令作用以及用法
|
JavaScript
Vue中的v-bind指令的用法有哪些?
Vue中的v-bind指令的用法有哪些?
280 37
|
JavaScript 开发者 容器
vue指令和用法
vue指令和用法
130 0
|
JavaScript
vue指令用法
Vue.js中的指令是Vue的核心概念之一,它用于将数据绑定到DOM元素,让Vue响应用户操作,更新数据,并将数据同步到视图上。
120 0