iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Vue组件中如何使用防抖和节流
  • 371
分享到

Vue组件中如何使用防抖和节流

2023-06-21 20:06:32 371人浏览 独家记忆
摘要

这期内容当中小编将会给大家带来有关Vue组件中如何使用防抖和节流,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Vue组件中如何使用防抖和节流?下面通过示例带大家了解一下Vue组件中使用防抖和节流控制观察者

这期内容当中小编将会给大家带来有关Vue组件中如何使用防抖和节流,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

Vue组件中如何使用防抖和节流?

下面通过示例带大家了解一下Vue组件中使用防抖和节流控制观察者和事件处理程序的方法。

在监听频繁触发的事件时,一定要多加小心,比如 用户在输入框打字、窗口大小调整、滚动、Intersection Observer 事件。

这些事件总是被频繁触发,可能 几秒一次。如果针对每次事件都发起 fetch 请求(或类似的行为),那显然是不明智的。

我们需要做的就是减缓事件处理程序的执行速度。这种缓冲技术就是 防抖(debounce) 和 节流(throttle) 。

在本文中,你会了解到如何在 Vue 组件中 使用 防抖 和 节流 控制 观察者(watchers) 和 事件处理程序。

1. 观察者 防抖

我们先从一个简单的组件开始,我们的任务是 将用户输入到 文本框中的文本 输出到控制台:

<template>  <input v-model="value" type="text" />  <p>{{ value }}</p></template><script>export default {  data() {    return {      value: "",    };  },  watch: {    value(newValue, oldValue) {      console.log("Value changed: ", newValue);    }  }};</script>

打开demo:

https://codesandbox.io/s/vue-input-szgn1?file=/src/App.vue

打开 demo,在 输入框 敲几个字符。每次输入时,值就会被 log 到控制台。

我们通过使用 观察者(watcher) 监听 value 数据属性 来实现了打印日志。但如果你想在 观察者的回调 中加入一个 使用 value 作为参数 的 GET 请求,那你应该不会期望太过频繁地发起请求。

我们来对 打印控制台日志 这个行为做一下 防抖。核心思想是创建一个 防抖函数,然后在 观察者 内部调用该函数。

我在这里选择了 'lodash.debounce' 的 防抖实现,但你可以自由选择喜欢的实现方式。

我们来将 防抖逻辑 应用到组件:

<template>  <input v-model="value" type="text" />  <p>{{ value }}</p></template><script>import debounce from "lodash.debounce";export default {  data() {    return {      value: "",    };  },  watch: {    value(...args) {      this.debouncedWatch(...args);    },  },  created() {    this.debouncedWatch = debounce((newValue, oldValue) => {      console.log('New value:', newValue);    }, 500);  },  beforeUnmount() {    this.debouncedWatch.cancel();  },};</script>

试试 demo

Https://codesandbox.io/s/vue-input-debounced-4vwex?file=/src/App.vue

如果你打开这个 demo,你会发现其实从用户角度来看,变化不大:你依旧可以像上一个 demo 中一样自由输入字符。

但有一个区别:只有在最后一次输入的 500ms 之后,才会将新的输入值打印日志到控制台。这说明 防抖 在生效。

观察者 的 防抖实现 只需要 3 个简单步骤:

  • create() 钩子 里,创建 防抖回调,并将其赋值到实例上:this.debouncedWatch = debounce(..., 500)

  • 在 观察者 回调 watch.value() { ... }  中 传入正确的参数 调用 this.debouncedWatch()

  • 最后,beforeUnmount() 钩子中 调用 this.debouncedWatch.cancel() ,在卸载组件之前,取消所有还在 pending 的 防抖函数执行。

采用同样的方式,你可以对任意数据属性的 观察者 应用 防抖。然后就可以安全执行 防抖回调内部的一些比较重的操作,比如 网络请求、繁重的 DOM 操作,等等。

2. 事件处理器 防抖

上面一节,我展示了如何对 观察者 使用 防抖,那么常规的事件处理器呢?

我们重用之前用户输入数据到输入框的例子,但这一次会给输入框加个 事件处理器。

像往常一样,如果你没有采取任何缓冲的措施,每当值被修改时,会被打印到控制台:

<template>  <input v-on:input="handler" type="text" /></template><script>export default {  methods: {    handler(event) {      console.log('New value:', event.target.value);    }  }};</script>

试试 demo:

https://codesandbox.io/s/vue-event-handler-plls4?file=/src/App.vue

打开这个 demo,在输入框打几个字符。看看控制台:你会发现每次你输入的时候就会有日志被打印出来。

同样,如果你会执行一些比较重的操作(比如网络请求),可就不合适了。

对 事件处理器 使用 防抖,可以参考下面这个:

<template>  <input v-on:input="debouncedHandler" type="text" /></template><script>import debounce from "lodash.debounce";export default {  created() {    this.debouncedHandler = debounce(event => {      console.log('New value:', event.target.value);    }, 500);  },  beforeUnmount() {    this.debouncedHandler.cancel();  }};</script>

试试 demo:

https://codesandbox.io/s/vue-event-handler-debounced-973vn?file=/src/App.vue

打开 demo,输入一些字符。组件只有在最后一次输入的 500ms 之后,才会将新的输入值打印日志到控制台。防抖 再一次生效了!

事件处理器 的 防抖实现 只需要 3 个步骤:

  • .在 create() 钩子 里,创建实例后,立刻将 防抖回调 debounce(event => {...}, 500) 赋值到 this.debouncedHandler

  • 在输入框的 template 中 给 v-on:input  赋上 debouncedHandler<input v-on:input="debouncedHandler" type="text" />

  • 最后,在卸载组件之前, 在 beforeUnmount() 钩子中 调用 this.debouncedHandler.cancel() ,取消所有还在 pending 的 函数调用。

另一方面,这些例子应用了 防抖 的技术。然而,同样的方式可以以用于创建 节流函数。

3. 注意

你可能不理解:为什么不直接在 组件的 method 选项中创建 防抖函数,然后在 template 中调用这些方法作为事件处理器?

// ...  methods: {    // Why not?    debouncedHandler: debounce(function () { ... }}, 500)  }// ...

这比在实例对象上创建 防抖函数 要简单的多。

例如:

<template>  <input v-on:input="debouncedHandler" type="text" /></template><script>import debounce from "lodash.debounce";export default {  methods: {    // Don't do this!    debouncedHandler: debounce(function(event) {      console.log('New value:', event.target.value);    }, 500)  }};</script>

试试 demo

https://codesandbox.io/s/vue-event-handler-debounced-incorrectly-320ci?file=/src/App.vue

这次不是在 created() 钩子 里创建 防抖回调了,而是将 防抖回调 赋给了 methods.debouncedHandler

你如果试过 demo,你会发现是有效果的!

问题是,组件使用 export default { ... } 导出的 options 对象,包括方法,会被组件实例重用。

如果网页中有 2 个以上的组件实例,那么所有的组件都会应用 相同 的防抖函数 methods.debouncedHandler  — 这会导致防抖出现故障。

4. 总结

在 Vue 中,可以很轻松的对 观察者 和 事件处理器 应用 防抖 和 节流。

核心逻辑就是,在 created() 钩子 里,创建 防抖 或 节流 的回调,并赋值在实例上。

// ...  created() {    this.debouncedCallback = debounce((...args) => {      // The debounced callback    }, 500);  },// ...

A)然后在观察者内部调用实例上的防抖函数:

// ...  watch: {    value(...args) {      this.debouncedCallback(...args);    },  },// ...

B)或在 template 中设定一个事件处理器:

<template>  <input v-on:input="debouncedHandler" type="text" /></template>

在这之后,每次调用 this.debouncedCallback(...args) ,就算执行频率非常高,内部的回调也能缓冲执行。

上述就是小编为大家分享的Vue组件中如何使用防抖和节流了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网精选频道。

--结束END--

本文标题: Vue组件中如何使用防抖和节流

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

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

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

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

下载Word文档
猜你喜欢
  • Vue组件中如何使用防抖和节流
    这期内容当中小编将会给大家带来有关Vue组件中如何使用防抖和节流,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Vue组件中如何使用防抖和节流?下面通过示例带大家了解一下Vue组件中使用防抖和节流控制观察者...
    99+
    2023-06-21
  • Vue组件中怎么使用防抖和节流
    本篇内容介绍了“Vue组件中怎么使用防抖和节流”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在监听频繁触发的事件时,一定要多加小心,比如 用...
    99+
    2023-06-21
  • vue中如何使用防抖和节流
    本篇文章给大家分享的是有关vue中如何使用防抖和节流,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。概念说白了, 防抖节流就是使用定时器 来实现我们的目的。防抖(debounce...
    99+
    2023-06-20
  • Vue组件中使用防抖和节流实例分析
    在监听频繁触发的事件时,一定要多加小心,比如 用户在输入框打字、窗口大小调整、滚动、Intersection Observer 事件。 这些事件总是被频繁触发,可能 几秒一次。如果针...
    99+
    2024-04-02
  • Vue防抖和节流怎么使用
    这篇文章主要介绍“Vue防抖和节流怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue防抖和节流怎么使用”文章能帮助大家解决问题。1. 观察者 防抖我们先从一个简单的组件开始,我们的任务是 ...
    99+
    2023-07-05
  • vue中防抖和节流的使用方法
    目录前言概念防抖定义使用场景代码在vue中使用节流定义使用场景代码在vue中使用总结前言 在一个电影项目中,我想在电影的列表中,保存下拉的当前位置,防止你切换页面后,再切换回当前的电...
    99+
    2024-04-02
  • Vue中使用防抖与节流的方法
    目录何为防抖/节流防抖(debounce)节流(throttle)页面使用使用场景总结何为防抖/节流 首先先说说何为防抖与节流 防抖(debounce) 防抖就是一段时间内会多次触发...
    99+
    2024-04-02
  • vue中使用闭包(防抖和节流)失效问题
    目录1. 出现问题2. 问题原因3. 解决办法4. 防抖节流函数1. 出现问题 防抖/节流使用无效,(例如防抖,按钮点击多次依旧执行多次)----> 查看是闭包无效,定义的局部...
    99+
    2023-05-18
    vue 闭包失效 vue 闭包
  • Vue面试必备之防抖和节流的使用
    目录1. 观察者 防抖2. 事件处理器 防抖3. 注意4. 总结在监听频繁触发的事件时,一定要多加小心,比如 用户在输入框打字、窗口大小调整、滚动、Intersection Obse...
    99+
    2023-03-24
    Vue防抖 节流使用 Vue 防抖 节流 Vue防抖 Vue节流
  • Vue防抖与节流的使用介绍
    目录概念1. 防抖2. 节流策略Vue中的使用概念 1. 防抖 防抖策略(debounce):是当事件被触发后,延迟n秒后再执行回调函数,如果在这n秒内事件被再次触发,则重新计时. ...
    99+
    2022-12-21
    Vue节流 Vue防抖
  • js如何实现防抖和节流
    这篇文章给大家分享的是有关js如何实现防抖和节流的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。防抖 & 节流防抖和节流属于高阶技巧,业务中比较多见的场合也就是搜索内容改变提示信息。即使不加也也不一定能看出...
    99+
    2023-06-27
  • Vue怎么使用lodash进行防抖节流
    本文小编为大家详细介绍“Vue怎么使用lodash进行防抖节流”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue怎么使用lodash进行防抖节流”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Lodash在Vu...
    99+
    2023-07-06
  • 如何在Vue2.x项目中使用防抖和节流功能
    本篇文章为大家展示了如何在Vue2.x项目中使用防抖和节流功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。vue是什么软件Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它...
    99+
    2023-06-06
  • Vue中click事件防抖和节流处理的示例分析
    小编给大家分享一下Vue中click事件防抖和节流处理的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!函数防抖定义:多次...
    99+
    2024-04-02
  • Vue使用lodash进行防抖节流的实现
    目录LodashdebouncethrottleLodash 在Vue中,可以通过使用Lodash库中提供的防抖和节流函数来有效地控制事件的触发次数,以提高页面性能。具体实现如下: ...
    99+
    2023-05-15
    Vue lodash防抖节流 Vue 防抖节流
  • 详解Java中的防抖和节流
    目录概念防抖(debounce)节流(throttle)区别Java实现防抖(debounce)防抖测试1防抖测试2防抖测试简易版节流(throttle)节流测试1彩蛋解决方法1解决...
    99+
    2022-11-13
    Java防抖 Java 节流 Java 防抖 节流
  • Vue 2中实现CustomRef方式防抖节流
    目录前言背景撸代码防抖(debounce)代码使用节流(throttle)代码使用总结前言 今天给大家带来的是Vue 2 中的实现 CustomRef 方式防抖/节流这篇文章,前几...
    99+
    2023-02-12
    Vue 2 CustomRef防抖节流 Vue CustomRef
  • JavaScript防抖与节流怎么使用
    这篇文章主要讲解了“JavaScript防抖与节流怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript防抖与节流怎么使用”吧!前言:防抖(Debounce) ...
    99+
    2023-06-30
  • 怎么理解javascript中防抖和节流
    本篇内容介绍了“怎么理解javascript中防抖和节流”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • 如何分析JS函数的防抖和节流
    如何分析JS函数的防抖和节流,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。节流实质上是:如果你持续触发事件,每隔一段时间,只执行一次事件。根据这个需求我们可以通...
    99+
    2023-06-03
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作