广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue防抖实例分析
  • 210
分享到

vue防抖实例分析

2024-04-02 19:04:59 210人浏览 八月长安
摘要

本篇内容介绍了“Vue防抖实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

本篇内容介绍了“Vue防抖实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

在vue中,防抖是指在事件被触发n秒后再执行回调,如果在这n秒内又被触发,则重新计时;也就是说:当持续触发某事件时,一定时间间隔内没有再触发事件时,事件处理函数才会执行一次,如果设定的时间间隔到来之前,又一次触发了事件,就重新开始延时。

vue防抖实例分析

教程操作环境:windows7系统、vue3版,DELL G3电脑。

防抖(debounce)

在事件被触发n秒后再执行回调,如果在这n秒内又被触发,则重新计时;

解释:当持续触发某事件时,一定时间间隔内没有再触发事件时,事件处理函数才会执行一次,如果设定的时间间隔到来之前,又一次触发了事件,就重新开始延时。

通俗理解,就是我们在点击请求或者点击加载等过程中,只需要点击一次,但由于请求慢,点击了好多次,导致多次请求,防抖就是在点击了好多次之后的最后一次才会请求。

案例1:

持续触发scroll事件时,并不立即执行handle函数,当1000毫秒内没有触发scroll事件时,才会延时触发一次handle函数。

function debounce(fn, wait) {
 let timeout = null
 return function() {
  if(timeout !== null) clearTimeout(timeout)   
  timeout = setTimeout(fn, wait);
 }
}
function handle() {  
 console.log(Math.random())
}
window.addEventListener('scroll', debounce(handle, 1000))

addEventListener的第二个参数实际上是debounce函数里return回的方法,let timeout = null 这行代码只在addEventListener的时候执行了一次 触发事件的时候不会执行,那么每次触发scroll事件的时候都会清除上次的延时器同时记录一个新的延时器,当scroll事件停止触发后最后一次记录的延时器不会被清除可以延时执行,这是debounce函数的原理

案例2:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta Http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>防抖</title>
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        输入内容:<input type="text"  @keyup="deb"/>
        <div> 输入次数:{{num}}</div>
    </div>
    <script>
        let time
        var app=new Vue({
            el:'#app',
            data:{
                num:0,
            },
            methods:{
                deb: function () {
let that = this
if (time) {
clearTimeout(time)
}
time = setTimeout(function () {
                            that.num++
console.log('输入了'+that.num+'次')
time = undefined;
}, 2000)
}
            }
        })
    </script>
</body>
</html>

效果图:(输入一次文字2秒后执行,多次输入,还是执行一次,输入次数只加1):

全局定义的time是undefind , 在连续输入的过程中,多次触发keyup事件,定时器每次都会重新渲染,仅当输入间隔超过(或等于)所设时间2秒时,num++才会执行。

vue防抖实例分析

搭配键盘修饰符:(.enter为例)

    <div id="app">
        输入内容:<input type="text" class="input"  @keyup.enter="deb"/>
        <div> 输入次数:{{num}}</div>
    </div>

这样连续按回车后,也只会触发一次 输入 ,每次按回车间隔设置的两秒,才会触发一次。

所以,考虑到会出现连续点击了提交按钮,连续触摸的情况,防抖是很有必要的。

当然,也有另外的解决方式,比如项目里用的是控制按钮的方式,点击保存,在请求接口返回200之前,按钮禁止使用,这里就不会出现重复点击了。

“vue防抖实例分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: vue防抖实例分析

本文链接: https://www.lsjlt.com/news/98336.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue防抖实例分析
    本篇内容介绍了“vue防抖实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-10-19
  • JavaScript节流与防抖实例分析
    本篇内容主要讲解“JavaScript节流与防抖实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript节流与防抖实例分析”吧!一、js防抖和节流在进行窗口的resize、sc...
    99+
    2023-06-29
  • Vue组件中使用防抖和节流实例分析
    在监听频繁触发的事件时,一定要多加小心,比如 用户在输入框打字、窗口大小调整、滚动、Intersection Observer 事件。 这些事件总是被频繁触发,可能 几秒一次。如果针...
    99+
    2022-11-12
  • JavaScript中防抖的示例分析
    这篇文章给大家分享的是有关JavaScript中防抖的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。JavaScript的特点1.JavaScript主要用来向HTML页面添加交互行为。2.JavaScr...
    99+
    2023-06-06
  • Vue中click事件防抖和节流处理的示例分析
    小编给大家分享一下Vue中click事件防抖和节流处理的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!函数防抖定义:多次...
    99+
    2022-10-19
  • vue防抖怎么实现
    这篇文章主要介绍“vue防抖怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue防抖怎么实现”文章能帮助大家解决问题。1.首先新建一个 debounce.js 代码如下const debou...
    99+
    2023-06-27
  • js中函数节流与防抖的示例分析
    小编给大家分享一下js中函数节流与防抖的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!js 的节流与防抖函数防抖&nbs...
    99+
    2022-10-19
  • JS函数防抖和函数节流的示例分析
    这篇文章主要介绍JS函数防抖和函数节流的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!概述函数防抖和函数节流都是定义一个函数,该函数接收一个函数作为参数,并返回一个添加了防抖或节流功能后的函数。因此可以将函数...
    99+
    2023-06-15
  • vue实例分析
    本篇内容介绍了“vue实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  Vue (读音 /vjuː/,类似于 View) 是一套用于...
    99+
    2023-06-22
  • vue怎么实现lodash的debounce防抖
    这篇文章主要介绍“vue怎么实现lodash的debounce防抖”,在日常操作中,相信很多人在vue怎么实现lodash的debounce防抖问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue怎么实现lo...
    99+
    2023-07-04
  • PHP 防抖和防重复提交的实际效果分析与比较
    防抖和防重复提交是在Web开发中常见的两种技术手段。它们可以使用户在操作过程中获得更好的体验,同时也可以保证数据的准确性和安全性。在PHP开发中,使用适当的防抖和防重复提交机制能够有效地提高系统的可靠性和性能。一、防抖机制防抖是一种通过延迟...
    99+
    2023-10-21
    比较 效果分析 防抖 防重复提交
  • 如何分析JS函数的防抖和节流
    如何分析JS函数的防抖和节流,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。节流实质上是:如果你持续触发事件,每隔一段时间,只执行一次事件。根据这个需求我们可以通...
    99+
    2023-06-03
  • vue全局注册自定义指令防抖解析
    目录全局注册自定义指令防抖1、先建一个js文件2、在mian.js里面注册3、使用vue防抖的使用防抖函数在vue中直接使用vue中使用高阶组件vue中自定义指令使用全局注册自定义指...
    99+
    2022-11-13
  • JavaScript专题之underscore防抖实例学习
    目录前言防抖第一版thisevent 对象返回值立刻执行取消JavaScript 专题系列第一篇,讲解防抖,带你从零实现一个 underscore 的 debounce 函数 前言 ...
    99+
    2022-11-13
  • Vue业务实例分析
    这篇“Vue业务实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue业务实例分析”...
    99+
    2022-10-19
  • PHP 中的防抖和防重复提交的安全性分析
    引言:随着网站和应用程序的发展,Web 表单成为了与用户交互的重要方式之一。用户填写表单后点击提交按钮,服务器会接收并处理提交的数据。然而,由于网络延迟或用户误操作等原因,可能会导致表单的多次提交。重复提交不仅会增加服务器的负载,还可能引发...
    99+
    2023-10-21
    安全性分析 防抖 防重复提交
  • vue项目中实现按钮防抖方法
    目录1.新建 .js文件存放防抖方法2.引入防抖文件,methods中添加方法3.html代码1.新建 .js文件存放防抖方法 // 防抖 export const antiShak...
    99+
    2022-12-14
    vue 按钮防抖 vue实现防抖
  • Vue 2中实现CustomRef方式防抖节流
    目录前言背景撸代码防抖(debounce)代码使用节流(throttle)代码使用总结前言 今天给大家带来的是Vue 2 中的实现 CustomRef 方式防抖/节流这篇文章,前几...
    99+
    2023-02-12
    Vue 2 CustomRef防抖节流 Vue CustomRef
  • angular异步验证器防抖实例详解
    目录背景:防抖节流定义:代码实现:疑惑first()的使用单元测试fakeAsync;题外补充总结背景: 当前输入框的formControl设置了异步验证器,会根据当前的值进行请求后...
    99+
    2022-11-13
  • PHP 防抖和防重复提交技术的使用场景分析
    在开发网站或应用程序时,防抖和防重复提交是常见的需求,它们旨在提升用户体验和保证数据的安全。本文将分析这两种技术的使用场景,并提供具体的PHP代码示例。一、防抖技术的使用场景分析防抖技术的目标是限制用户频繁触发某个操作的次数,通常用于以下情...
    99+
    2023-10-21
    用户体验 防抖技术:性能 数据实时性 业务逻辑正确性
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作