当前位置: 首页 > article >正文

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的搜索框输入防抖功能。当用户在搜索框中输入时,会触发防抖函数,延迟一段时间后再执行搜索方法。这样可以有效减少搜索方法的执行次数,提高性能。


http://www.kler.cn/news/148704.html

相关文章:

  • 单片机复位电路
  • 【华为OD题库-036】跳格子2-java
  • springBoot设置多数据源
  • uniapp地图基本使用及解决添加markers不生效问题?
  • Linux shell编程学习笔记31:alias 和 unalias 操作 命令别名
  • 力扣 39. 组合总和 递归解法
  • Linux处理系统常见命令
  • [个人笔记] vCenter6.7使用自建SSL证书
  • UE5 范围内随机生成
  • 1. TiDB-Operator 备份到 Minio
  • RK3566RK3568 安卓11 在framework层进行串口通信
  • 【LeetCode】70. 爬楼梯
  • 服务器运行train.py报错解决
  • 成功的蓝图:实现长期成长与卓越表现的 6 项策略
  • 如何使用ArcGIS实现生态廊道模拟
  • 针对MySql知识的回顾
  • nodejs 如何将 Buffer 数据转为 String
  • 条形码格式
  • 位运算算法【1】
  • UI自动化的基本知识
  • Hive进阶函数:SPACE() 一行炸裂指定行
  • 【栈和队列(1)(逆波兰表达式)】
  • Ps:子路径的上下排列以及对齐与分布
  • 【开发实践】使用POI实现导出带有复杂表头的的excel文件
  • 璞华大数据产品入选中国信通院“铸基计划”
  • 【开源】基于Vue+SpringBoot的学校热点新闻推送系统
  • 梦极光(ez_re???)
  • MYSQL基础知识之【LIKE子句的使用 ,NULL值的处理,空值的处理】
  • ArrayList和顺序表
  • 服务器中深度学习环境的配置