vue項(xiàng)目使用lodash節(jié)流防抖函數(shù)問(wèn)題解決方案
背景
在lodash函數(shù)工具庫(kù)中,防抖 _.debounce
和節(jié)流 _.throttle
函數(shù)在一些頻繁觸發(fā)的事件中比較常用。
防抖函數(shù) _.debounce(func, [wait=0], [options=])
創(chuàng)建一個(gè) debounced(防抖動(dòng))函數(shù),該函數(shù)會(huì)從上一次被調(diào)用后,延遲 wait
毫秒后調(diào)用 func
方法。
參數(shù)
func
(Function): 要防抖動(dòng)的函數(shù)。[wait=0]
(number): 需要延遲的毫秒數(shù)。[options=]
(Object): 選項(xiàng)對(duì)象。[options.leading=false]
(boolean): 指定在延遲開始前調(diào)用。[options.maxWait]
(number): 設(shè)置func
允許被延遲的最大值。[options.trailing=true]
(boolean): 指定在延遲結(jié)束后調(diào)用。
返回
- (Function): 返回 debounced(防抖動(dòng))函數(shù)。
節(jié)流函數(shù) _.throttle(func, [wait=0], [options=])
創(chuàng)建一個(gè)節(jié)流函數(shù),在 wait
毫秒內(nèi)最多執(zhí)行 func
一次的函數(shù)。
參數(shù)
func
(Function): 要節(jié)流的函數(shù)。[wait=0]
(number): 需要節(jié)流的毫秒。[options=]
(Object): 選項(xiàng)對(duì)象。[options.leading=true]
(boolean): 指定調(diào)用在節(jié)流開始前。[options.trailing=true]
(boolean): 指定調(diào)用在節(jié)流結(jié)束后。
返回
(Function): 返回 throttled(節(jié)流)的函數(shù)。
在vue中使用防抖節(jié)流函數(shù)的問(wèn)題
踩坑1
防抖節(jié)流函數(shù)實(shí)際上起到一個(gè)“稀釋”的作用,在vue項(xiàng)目中我們可能會(huì)這樣寫(節(jié)流為例)。
<template> <div> <button @click="add_throttle">加1</button> <h1>{{ number }}</h1> </div> </template> <script> import { throttle } from 'lodash'; export default { data() { return { number: 1 }; }, methods: { // add函數(shù)做節(jié)流處理 add_throttle: throttle(this.add, 1000), add() { this.number++; } }, }; </script>
然后我們信心滿滿地F12打開控制臺(tái)……
上面說(shuō) add
這玩意兒 undefined
了。
這其實(shí)是 this
的指向問(wèn)題。實(shí)際上這里的 this
并不是vue實(shí)例(至于是什么,往下看你就知道了[doge]),所以自然不存在 add()
方法了。
踩坑2
既然直接使用 this.add()
不成,那我們換個(gè)思路,把 this.add()
放在函數(shù)里呢?
methods: { // 做節(jié)流處理 add_throttle: throttle(() => { this.add(); }, 1000), add() { this.number++; } }
然后,自信滿滿地再次打開控制臺(tái)……
第一眼,誒,沒(méi)報(bào)錯(cuò),于是點(diǎn)擊按鈕……
梅開二度……
其實(shí)還是 this
的指向問(wèn)題。我們知道箭頭函數(shù)是沒(méi)有 this
的,所以這里的 this
相當(dāng)于踩坑1里的 this
,讓我們打印下,揭開它的廬山真面目。
methods: { // 做節(jié)流處理 add_throttle: throttle(() => { console.log(this); }, 1000), add() { this.number++; } }
好家伙,原來(lái)這里的 this
本身就是 undefined
。
解決
既然是this的指向問(wèn)題,那么只要保證 this
指向vue實(shí)例就行了,箭頭函數(shù)換成聲明式函數(shù)。
methods: { // 做節(jié)流處理 add_throttle: throttle(function () { this.add(); }, 1000), add() { this.number++; } }
結(jié)果很nice。
至于為什么,大概是lodash的 _.debounce
函數(shù)對(duì)this做了一些處理( _.throttle
函數(shù)本質(zhì)還是調(diào)用了 _.debounce
函數(shù)),有興趣的小伙伴兒可以看看_.debounce
的源碼。
到此這篇關(guān)于vue項(xiàng)目使用lodash節(jié)流防抖函數(shù)問(wèn)題與解決的文章就介紹到這了,更多相關(guān)vue使用lodash節(jié)流防抖函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue項(xiàng)目中使用require.context引入組件
本文主要介紹了vue項(xiàng)目中使用require.context引入組件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08vue移動(dòng)端自適應(yīng)適配問(wèn)題詳解
這篇文章主要介紹了vue移動(dòng)端自適應(yīng)適配問(wèn)題,本文通過(guò)實(shí)例代碼詳解給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-04-04vue動(dòng)態(tài)添加路由后刷新頁(yè)面白屏問(wèn)題及解決
這篇文章主要介紹了vue動(dòng)態(tài)添加路由后刷新頁(yè)面白屏問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04使用ElementUI寫一個(gè)前端分頁(yè)查詢的實(shí)例
本文主要介紹了使用ElementUI寫一個(gè)前端分頁(yè)查詢的實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02ElementUI?el-table?樹形數(shù)據(jù)的懶加載的實(shí)現(xiàn)
當(dāng)面對(duì)大量數(shù)據(jù)時(shí),一次性加載所有數(shù)據(jù)可能會(huì)導(dǎo)致性能問(wèn)題,我們可以實(shí)現(xiàn)樹形數(shù)據(jù)的懶加載,本文主要介紹了ElementUI?el-table?樹形數(shù)據(jù)的懶加載,感興趣的可以了解一下2024-06-06Vue.js 中 ref 和 reactive 的區(qū)別及用法解析
在Vue.js中,ref主要用于創(chuàng)建響應(yīng)式的引用,通過(guò).value屬性來(lái)訪問(wèn)和修改值,特別適用于需要頻繁更改整個(gè)值的場(chǎng)景,而reactive則用于創(chuàng)建深度響應(yīng)的對(duì)象或數(shù)組,本文給大家介紹Vue.js 中 ref 和 reactive 的區(qū)別及用法,感興趣的朋友跟隨小編一起看看吧2024-09-09element-UI el-table修改input值視圖不更新問(wèn)題
這篇文章主要介紹了element-UI el-table修改input值視圖不更新問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02