第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

跪求!防抖和節(jié)流里邊的 arguments是誰的啊萬分感謝

跪求!防抖和節(jié)流里邊的 arguments是誰的啊萬分感謝

qq_遁去的一_1 2019-07-28 12:32:46
functiondebounce(fn,wait,immediate){vartimer=nullreturnfunction(){varargs=argumentsvarcontext=thisif(immediate&&!timer){fn.apply(context,args)}if(timer){clearTimeout(timer)}timer=setTimeout(function(){fn.apply(context,args)},wait)}}一直沒搞清楚,這個arguments是debounce這個函數(shù)的嗎?請大佬詳細講講。用apply綁定,是與閉包有關(guān)嗎?
查看完整描述

2 回答

?
阿波羅的戰(zhàn)車

TA貢獻1862條經(jīng)驗 獲得超6個贊

假設(shè)你現(xiàn)在監(jiān)聽了一個鼠標移動事件:
functionhandler(e){console.log(e,this);}
el.onmousemove=handler;
當觸發(fā)事件時,打印得到事件對象以及當前元素(el)。
現(xiàn)在給事件處理函數(shù)加上了防抖:el.onmousemove=debounce(handler)。對于debounce(handler),返回值是一個函數(shù),所以等同于el.onmousemove=denouceHandler,只是一個新的事件處理函數(shù)而已,它的參數(shù)中就會包含事件對象,也就是arguments中包含事件對象。
至于fn.apply(context,args),前面提到handler中打印this可以拿到正確的值(當前元素),這里即改變this的指向。于是乎在加了防抖函數(shù)之后去觸發(fā)事件時,才能保證fn內(nèi)部能夠拿到事件對象以及正確的this值
                            
查看完整回答
反對 回復(fù) 2019-07-28
  • 2 回答
  • 0 關(guān)注
  • 240 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號