文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何在Vue2.x项目中使用防抖和节流功能

2023-06-06 16:37

关注

本篇文章为大家展示了如何在Vue2.x项目中使用防抖和节流功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

vue是什么软件

Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区别是,使用Vue可以自底向上逐层应用,其核心库只关注视图层,方便与第三方库和项目整合,且使用Vue可以采用单文件组件和Vue生态系统支持的库开发复杂的单页应用。

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项目中使用防抖和节流功能,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯