日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

手写防抖和节流中的一些细节

發(fā)布時(shí)間:2023/12/20 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 手写防抖和节流中的一些细节 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

使用函數(shù)節(jié)流與函數(shù)防抖的目的,就是為了節(jié)約計(jì)算機(jī)資源,提升用戶體驗(yàn)。js中的一些事件如瀏覽器的resize、scroll,鼠標(biāo)的mousemove、mouseover,input輸入框的keypress等事件在觸發(fā)時(shí),會(huì)不斷地調(diào)用綁定在事件上的回調(diào)函數(shù),極大地浪費(fèi)資源,降低前端性能。為了優(yōu)化體驗(yàn),需要對(duì)這類事件進(jìn)行調(diào)用次數(shù)的限制。

防抖:短時(shí)間內(nèi)大量觸發(fā),但只執(zhí)行一次。原理:設(shè)置定時(shí)器,delay時(shí)間后執(zhí)行事件處理,期間每次觸發(fā)事件都會(huì)將定時(shí)器重置,直到delay時(shí)間內(nèi)無第二次事件觸發(fā)。

function debounce (func, delay) {let task = nullreturn function (...args) {if (task) {clearTimeout(task)}task = setTimeout(() => {func.apply(this, args)}, delay)} }// 使用 let debounceFunc = debounce(scrollEvent, 300) document.getElementById("my_input").addEventListener("keydown", function () {debounceFunc(456) }) function scrollEvent(args) {console.log("滾動(dòng)" + args);//滾動(dòng)456 }

節(jié)流:隔一段時(shí)間執(zhí)行一次,期間被多次觸發(fā)也不管。實(shí)現(xiàn)原理:設(shè)置定時(shí)器,delay時(shí)間后執(zhí)行事件處理,當(dāng)事件執(zhí)行完后清除定時(shí)器。

function throttle (func, delay) {let task = nullreturn function (...args) {if (!task) {task = setTimeout (() => {task = nullfunc.apply(this, args)}, delay)}}}// 使用 let throttleFunc = throttle(scrollEvent, 300) document.addEventListener("scroll", function () {throttleFunc(123) }) function scrollEvent(args) {console.log("滾動(dòng)" + args); }

對(duì)于兩函數(shù)中的func.apply(this, args),之前感覺一直沒弄清楚,于是查了很多資料,以下是自己的分析。

知識(shí)點(diǎn)詳解:

1.定時(shí)器回調(diào)函數(shù)中的this指向問題:

(1)如果沒有特殊指向,setInterval和setTimeout的回調(diào)函數(shù)中this的指向都是window。這是因?yàn)镴S的定時(shí)器方法是定義在window下的。

(2)call,apply,bind可以修改this指向

(3)箭頭函數(shù)沒有自己的this,它的this繼承自外部函數(shù)的作用域。

因此上面代碼setTimeout中的this繼承外層匿名函數(shù)的this,也就是節(jié)流和防抖函數(shù)的調(diào)用者。

2.apply方法的使用

Function.apply(obj,args)可將函數(shù)的this對(duì)象指向obj,args則為函數(shù)的輸入?yún)?shù),以數(shù)組形式傳入。

上面代碼中func.apply(this, args)則是將func的this指向改為setTimeout中的this,也就是將func的this指向改為節(jié)流和防抖函數(shù)的調(diào)用者。

上文所寫的節(jié)流和防抖函數(shù)的返回值是一個(gè)函數(shù),因此在調(diào)用時(shí)可以給其傳參,輸入?yún)?shù)可以使用剩余參數(shù)語法(...rest)寫入返回的匿名函數(shù)中function (args),并利用func.apply(this, args)的第二個(gè)參數(shù)傳給func。

總結(jié)

以上是生活随笔為你收集整理的手写防抖和节流中的一些细节的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。