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项目设置resolves.alias: '@'路径并适配webstorm
Dec 02 Vue.js
浅谈Vue使用Elementui修改默认的最快方法
Dec 05 Vue.js
Vue 实现一个简单的鼠标拖拽滚动效果插件
Dec 10 Vue.js
vue keep-alive的简单总结
Jan 25 Vue.js
vue集成一个支持图片缩放拖拽的富文本编辑器
Jan 29 Vue.js
vite2.0+vue3移动端项目实战详解
Mar 03 Vue.js
vue+django实现下载文件的示例
Mar 24 Vue.js
vue如何批量引入组件、注册和使用详解
May 12 Vue.js
Vue中foreach数组与js中遍历数组的写法说明
Jun 05 Vue.js
vue实现锚点定位功能
Jun 29 Vue.js
vue生命周期钩子函数以及触发时机
Apr 26 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
用PHP读注册表
2006/10/09 PHP
PHP多维数组转一维数组的简单实现方法
2015/12/23 PHP
Yii2中OAuth扩展及QQ互联登录实现方法
2016/05/16 PHP
php编程实现简单的网页版计算器功能示例
2017/04/26 PHP
TP3.2.3框架使用CKeditor编辑器在页面中上传图片的方法分析
2019/12/31 PHP
jQuery学习笔记之jQuery选择器的使用
2010/12/22 Javascript
一些有用的JavaScript和jQuery的片段分享
2011/08/23 Javascript
用js代码改变单选框选中状态的简单实例
2013/12/18 Javascript
node.js解决获取图片真实文件类型的问题
2014/12/20 Javascript
jQuery滚动条插件nanoscroller使用指南
2015/04/21 Javascript
基于AngularJS前端云组件最佳实践
2016/10/20 Javascript
JavaScript中捕获/阻止捕获、冒泡/阻止冒泡方法
2016/12/07 Javascript
js实现图片加载淡入淡出效果
2017/04/07 Javascript
解决vue接口数据赋值给data没有反应的问题
2018/08/27 Javascript
小程序云开发部署攻略(图文教程)
2018/10/30 Javascript
小程序实现短信登录倒计时
2019/07/12 Javascript
简单实现节流函数和防抖函数过程解析
2019/10/08 Javascript
Vue实现简单的留言板
2020/10/23 Javascript
python实现得到一个给定类的虚函数
2014/09/28 Python
python爬虫超时的处理的实例
2018/12/19 Python
Django密码系统实现过程详解
2019/07/19 Python
Python IDE Pycharm中的快捷键列表用法
2019/08/08 Python
Python猴子补丁知识点总结
2020/01/05 Python
python实现批量修改文件名
2020/03/23 Python
python计算Content-MD5并获取文件的Content-MD5值方式
2020/04/03 Python
python中tkinter窗口位置\坐标\大小等实现示例
2020/07/09 Python
基于CSS3实现立方体自转效果
2016/03/01 HTML / CSS
Canvas获取视频第一帧缩略图的实现
2020/11/11 HTML / CSS
adidas旗下高尔夫装备供应商:TaylorMade Golf(泰勒梅高尔夫)
2016/08/28 全球购物
存储过程的优缺点是什么
2015/01/10 面试题
销售顾问岗位职责
2014/02/25 职场文书
药剂专业个人求职信范文
2014/04/29 职场文书
农行心得体会
2014/09/02 职场文书
加强作风建设演讲稿
2014/10/24 职场文书
个人向公司借款协议书
2016/03/19 职场文书
解决Mysql中的innoDB幻读问题
2022/04/29 MySQL