Keys's stuff Keys's stuff
首页
  • JavaScript
  • CSS
  • 技术文档
  • GitHub
  • Nodejs
  • NPM
  • 博客搭建
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
  • 常用工具 (opens new window)
  • 索引

    • 分类
    • 标签
    • 归档
  • 网站工具参考
  • 常用类库组件
  • HTML参考手册 (opens new window)
  • 后端博客参考 (opens new window)
  • ChatGPT入门介绍 (opens new window)
  • JavaScript 教程 (opens new window)
  • ES6教程 (opens new window)
  • VUE (opens new window)
  • GIT (opens new window)
  • 学习笔记

    • 《JavaScript高级程序设计》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • TypeScript
    • JS设计模式总结
关于
GitHub (opens new window)

Keys Xu

音乐的力量
首页
  • JavaScript
  • CSS
  • 技术文档
  • GitHub
  • Nodejs
  • NPM
  • 博客搭建
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
  • 常用工具 (opens new window)
  • 索引

    • 分类
    • 标签
    • 归档
  • 网站工具参考
  • 常用类库组件
  • HTML参考手册 (opens new window)
  • 后端博客参考 (opens new window)
  • ChatGPT入门介绍 (opens new window)
  • JavaScript 教程 (opens new window)
  • ES6教程 (opens new window)
  • VUE (opens new window)
  • GIT (opens new window)
  • 学习笔记

    • 《JavaScript高级程序设计》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • TypeScript
    • JS设计模式总结
关于
GitHub (opens new window)
  • Vue》笔记

    • 基础

    • 组件

    • 过渡&动画

    • 可复用性&组合

    • 工具

    • 规模化

    • Vuex

    • 其他

      • Vue中的防抖函数封装和使用
        • 操作本地缓存
    • TypeScript 从零实现 axios》

    • React》笔记

    • Git》学习笔记

    • 学习笔记

    • oldNote
    • Vue》笔记
    • 其他
    xugaoyi
    2020-02-04
    目录

    Vue中的防抖函数封装和使用

    # Vue中的防抖函数封装和使用

    如搜索框中,每改变一个数值就请求一次搜索接口,当快速的改变数值时并不需要多次请求接口,这就需要一个防抖函数:

    // 防抖函数
    export function debounce(func, delay) { // func 函数 delay间隔时间
      let timer
      return function (...args) {
        if (timer) {
          clearTimeout(timer)
        }
        timer = setTimeout(() => {
          func.apply(this, args)
        }, delay)
      }
    }
    
    
    
    
    //使用:
    import { debounce } from '@/common/js/util'
    
    created() {
        /**
         * 为什么不直接在watch里面写???
         * 因为要做防抖处理,防止在快速输入时多次请求接口
         */
        this.$watch('query', debounce((newQuery) => {
          this.$emit('query', newQuery)
        }, 200))
      }
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28

    # 相关文章

    防抖与节流函数 (opens new window)

    编辑 (opens new window)
    #Vue
    上次更新: 2022/02/22, 09:46:22
    Vuex
    操作本地缓存

    ← Vuex 操作本地缓存→

    最近更新
    01
    2023工作展望xx
    02-13
    02
    2023工作展望
    02-13
    03
    程序员技术指南
    01-18
    更多文章>
    Theme by Vdoing | Copyright © 2019-2023 Keys Xu | MIT License
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式