Vue2.x-使用防抖以及节流的示例


Posted in Vue.js onMarch 02, 2021

utils:

// 防抖
export const debounce = (func, wait = 3000, immediate = true) => {
 let timeout = null;
 return function() {
  let context = this;
  let args = arguments;
  if (timeout) clearTimeout(timeout);
  if (immediate) {
   var callNow = !timeout; //点击第一次为true 时间内点击第二次为false 时间结束则重复第一次
   timeout = setTimeout(() => {
    timeout = null;
   }, wait); //定时器ID
   if (callNow) func.apply(context, args);
  } else {
   timeout = setTimeout(function() {
    func.apply(context, args);
   }, wait);
  }
 };
};
// 时间戳方案
export const throttleTime = (fn, wait = 2000) => {
 var pre = Date.now();
 return function() {
  var context = this;
  var args = arguments;
  var now = Date.now();
  if (now - pre >= wait) {
   fn.apply(context, args);
   pre = Date.now();
  }
 };
};
// 定时器方案
export const throttleSetTimeout = (fn, wait = 3000) => {
 var timer = null;
 return function() {
  var context = this;
  var args = arguments;
  if (!timer) {
   timer = setTimeout(function() {
    fn.apply(context, args);
    timer = null;
   }, wait);
  }
 };
};

vue中使用:

<template>
 <div class="main">
  <p>防抖立即执行</p>
  <button @click="click1">点击</button>

  <br />

  <p>防抖不立即执行</p>
  <button @click="click2">点击</button>

  <br />

  <p>节流时间戳方案</p>
  <button @click="click3">点击</button>

  <br />

  <p>节流定时器方案</p>
  <button @click="click4">点击</button>
 </div>
</template>

<script>
import { debounce, throttleTime, throttleSetTimeout } from './utils';
export default {
 methods: {
  click1: debounce(
   function() {
    console.log('防抖立即执行');
   },
   2000,
   true
  ),
  click2: debounce(
   function() {
    console.log('防抖不立即执行');
   },
   2000,
   false
  ),
  click3: throttleTime(function() {
   console.log('节流时间戳方案');
  }),
  click4: throttleSetTimeout(function() {
   console.log('节流定时器方案');
  })
 },
};
</script>

<style scoped lang="scss">
* {
 margin: 0;
 font-size: 20px;
 user-select: none;
}
.main {
 position: absolute;
 left: 50%;
 transform: translateX(-50%);
 width: 500px;
}
button {
 margin-bottom: 100px;
}
</style>

解释:

防抖:

立即执行版本:immediate为true,则点击第一次就执行,再继续点击则不执行,当wait时间结束后,再点击则生效,也就是只执行第一次。

原理:

点击第一次不存在timeoutID,并且callNow为true,则立即执行目标代码,点击第二次时存在了timeoutID,并且callNow为false,所以不执行目标代码,当wait时间结束后,把timeoutID设为null,则开始重复立即执行逻辑。

不立即执行版:immediate为false,则点击第一次不执行,当wait时间结束后,才生效,也就是无论点击多少次,只执行最后一次点击事件

原理:

使用setTimeout延迟执行事件,如果多次触发,则clearTimeout上次执行的代码,重新开始计时,在计时期间没有触发事件,则执行目标代码。

节流:

连续触发事件时以wait频率执行目标代码。

效果:

Vue2.x-使用防抖以及节流的示例

以上就是Vue2.x-使用防抖以及节流的示例的详细内容,更多关于vue 防抖及节流的资料请关注三水点靠木其它相关文章!

Vue.js 相关文章推荐
Vue +WebSocket + WaveSurferJS 实现H5聊天对话交互的实例
Nov 18 Vue.js
VUE+Element实现增删改查的示例源码
Nov 23 Vue.js
vue打开其他项目页面并传入数据详解
Nov 25 Vue.js
Vue ​v-model相关知识总结
Jan 28 Vue.js
Vue 实现可视化拖拽页面编辑器
Feb 01 Vue.js
详解Vue的七种传值方式
Feb 08 Vue.js
vue+springboot实现登录验证码
May 27 Vue.js
Vue CLI中模式与环境变量的深入详解
May 30 Vue.js
vue响应式原理与双向数据的深入解析
Jun 04 Vue.js
Vue实现tab导航栏并支持左右滑动功能
Jun 28 Vue.js
使用vuex-persistedstate本地存储vuex
Apr 29 Vue.js
Vue操作Storage本地化存储
Apr 29 Vue.js
Vue中避免滥用this去读取data中数据
Mar 02 #Vue.js
vue脚手架项目创建步骤详解
Mar 02 #Vue.js
vue-cli中实现响应式布局的方法
Mar 02 #Vue.js
vue实现桌面向网页拖动文件的示例代码(可显示图片/音频/视频)
Mar 01 #Vue.js
vue 使用饿了么UI仿写teambition的筛选功能
Mar 01 #Vue.js
vue实现拖拽进度条
Mar 01 #Vue.js
vue 使用 v-model 双向绑定父子组件的值遇见的问题及解决方案
Mar 01 #Vue.js
You might like
改进的IP计数器
2006/10/09 PHP
DedeCms模板安装/制作概述
2007/03/11 PHP
php实现首页链接查询 友情链接检查的代码
2010/01/05 PHP
使用php get_headers 判断URL是否有效的解决办法
2013/04/27 PHP
php+mysqli使用预处理技术进行数据库查询的方法
2015/01/28 PHP
PHP实现随机生成水印图片功能
2017/03/22 PHP
PHP封装的非对称加密RSA算法示例
2018/05/28 PHP
PHP基于DateTime类解决Unix时间戳与日期互转问题【针对1970年前及2038年后时间戳】
2018/06/13 PHP
php实现小程序支付完整版
2018/10/09 PHP
php实现二叉树中和为某一值的路径方法
2018/10/14 PHP
ThinkPhP+Apache+PHPstorm整合框架流程图解
2020/11/23 PHP
Jquery Ajax请求代码(2)
2011/01/07 Javascript
Extjs显示从数据库取出时间转换JSON后的出现问题
2012/11/20 Javascript
Js 获取Gridview选中行的内容操作步骤
2013/02/05 Javascript
java和javascript获取word文档的书签位置对比
2014/06/19 Javascript
移动开发之自适应手机屏幕宽度
2016/11/23 Javascript
fullCalendar中文API官方文档
2017/02/07 Javascript
JS中input表单隐藏域及其使用方法
2017/02/13 Javascript
原生js+cookie实现购物车功能的方法分析
2017/12/21 Javascript
详解使用jQuery.i18n.properties实现js国际化
2018/05/04 jQuery
elementUI 设置input的只读或禁用的方法
2018/10/30 Javascript
cocos2dx+lua实现橡皮擦功能
2018/12/20 Javascript
JSON获取属性值方法代码实例
2020/06/30 Javascript
[01:36]DOTA2完美大师赛趣味视频之与队友相处的十万个技巧
2017/11/19 DOTA
python基于pygame实现响应游戏中事件的方法(附源码)
2015/11/11 Python
浅析Git版本控制器使用
2017/12/10 Python
jupyter notebook 添加kernel permission denied的操作
2020/04/21 Python
Python使用多进程运行含有任意个参数的函数
2020/05/02 Python
Python批量删除mysql中千万级大量数据的脚本分享
2020/12/03 Python
萌新的HTML5 入门指南
2020/11/06 HTML / CSS
电子商务自荐书范文
2014/01/04 职场文书
开业庆典答谢词
2014/01/18 职场文书
清明节扫墓活动方案
2014/03/02 职场文书
周一给客户的问候语
2015/11/10 职场文书
matplotlib画混淆矩阵与正确率曲线的实例代码
2021/06/01 Python
Pytorch中的学习率衰减及其用法详解
2021/06/05 Python