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 相关文章推荐
ESLint 是如何检查 .vue 文件的
Nov 30 Vue.js
vue添加自定义右键菜单的完整实例
Dec 08 Vue.js
vue 通过base64实现图片下载功能
Dec 19 Vue.js
vue3中轻松实现switch功能组件的全过程
Jan 07 Vue.js
vue 页面跳转的实现方式
Jan 12 Vue.js
vue使用vue-quill-editor富文本编辑器且将图片上传到服务器的功能
Jan 13 Vue.js
使用vue3重构拼图游戏的实现示例
Jan 25 Vue.js
vue+django实现下载文件的示例
Mar 24 Vue.js
解决Vue+SpringBoot+Shiro跨域问题
Jun 09 Vue.js
Vue3.0 手写放大镜效果
Jul 25 Vue.js
vue实现书本翻页动画效果实例详解
Apr 08 Vue.js
vue中的可拖拽宽度div的实现示例
Apr 08 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
星际争霸秘籍
2020/03/04 星际争霸
星际争霸 Starcraft 游戏介绍
2020/03/14 星际争霸
php读取csv实现csv文件下载功能
2013/12/18 PHP
PHP实现递归目录的5种方法
2016/10/27 PHP
微信JSSDK分享功能图文实例详解
2019/04/08 PHP
PHP程序员简单的开展服务治理架构操作详解(一)
2020/05/14 PHP
xml和web特殊字符
2009/04/28 Javascript
JavaScript中字符串与Unicode编码互相转换的实现方法
2015/12/18 Javascript
浅谈JS使用[ ]来访问对象属性
2016/09/21 Javascript
基于Marquee.js插件实现的跑马灯效果示例
2017/01/25 Javascript
canvas绘制爱心的几种方法总结(推荐)
2017/10/31 Javascript
详解Vue CLI3 多页应用实践和源码设计
2018/08/30 Javascript
基于vue2的canvas时钟倒计时组件步骤解析
2018/11/05 Javascript
发布Angular应用至生产环境的方法
2018/12/10 Javascript
Windows下Node爬虫神器Puppeteer安装记
2019/01/09 Javascript
Vue移动端项目实现使用手机预览调试操作
2020/07/18 Javascript
解决vue.js中settimeout遇到的问题(时间参数短效果不稳定)
2020/07/21 Javascript
Vue前端判断数据对象是否为空的实例
2020/09/02 Javascript
跟老齐学Python之不要红头文件(2)
2014/09/28 Python
Python中AND、OR的一个使用小技巧
2015/02/18 Python
python统计字母、空格、数字等字符个数的实例
2018/06/29 Python
python2与python3的print及字符串格式化小结
2018/11/30 Python
Python实现的简单线性回归算法实例分析
2018/12/26 Python
python3使用QQ邮箱发送邮件
2020/05/20 Python
在python中创建指定大小的多维数组方式
2019/11/28 Python
使用html5+css3来实现slider切换效果告别javascript+css
2013/01/08 HTML / CSS
阿里巴巴国际站:Alibaba.com
2016/07/21 全球购物
草莓网美国官网:Strawberrynet USA
2016/12/11 全球购物
德国电子商城:ComputerUniverse
2017/04/21 全球购物
美国手机支架公司:PopSockets
2019/11/27 全球购物
Fnac西班牙官网:法国文化和电子产品零售商
2021/03/14 全球购物
小班重阳节活动方案
2014/02/08 职场文书
运动会演讲稿300字
2014/08/25 职场文书
财务科长个人对照检查材料
2014/09/18 职场文书
2015年见习期工作总结
2014/12/12 职场文书
2016年社区植树节活动总结
2016/03/16 职场文书