本篇文章给大家分享的是有关vue中如何使用防抖和节流,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
概念
说白了, 防抖节流就是使用定时器 来实现我们的目的。
防抖(debounce):
在事件被触发n秒后再执行回调,如果在这n秒内又被触发,则重新计时。
典型的案例就是输入框搜索:输入结束后n秒才进行搜索请求,n秒内又输入的内容,则重新计时。
节流(throttle):
规定在一个单位时间内,只能触发一次函数,如果这个单位时间内触发多次函数,只有一次生效。
典型的案例就是鼠标不断点击触发,规定在n秒内多次点击只生效一次。
防抖
定义
频繁操作防止抖动,在操作后 n 秒内不操作,才触发事件,若继续操作,则重新计时
使用场景
输入框输入
缩放resize
代码
// utils.js// immediate 是否开始立即执行function debounce(func, delay = 300, immediate = false) { let timer = null return function() { if (timer) { clearTimeout(timer) } if (immediate && !timer) { func.apply(this, arguments) } timer = setTimeout(() => { func.apply(this, arguments) }, delay) }}
在vue中使用
方法一:写在公共方法utils里引入
import { debounce } from 'utils'methods: { appSearch:debounce(function(e.target.value){ this.handleSearch(value) }, 1000), handleSearch(value) { console.log(value) }}
方法二:写在当前vue文件中
data: () => { return { debounceInput: () => {} }},methods: { showApp(value) { console.log('value', value) }, debounce(func, delay = 300, immediate = false) { let timer = null return function() { if (timer) { clearTimeout(timer) } if (immediate && !timer) { func.apply(this, arguments) } timer = setTimeout(() => { func.apply(this, arguments) }, delay) } }},mounted() { this.debounceInput = this.debounce(this.showApp, 1000) },
节流
定义
频繁操作稀释函数执行,频繁操作时,每隔n秒才触发一次
使用场景
鼠标点击,mousedown,mousemove单位时间只执行一次
滚动事件,懒加载、滚动加载、加载更多或监听滚动条位置
防止高频点击提交,防止表单重复提交
代码
// utils.jsfunction throttle (func, delay = 300) { let prev = 0 return function() { let now = Date.now() if ((now - prev) >= delay) { func.apply(this, arguments) prev = Date.now() } }}
以上就是vue中如何使用防抖和节流,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网行业资讯频道。