<font id="zqva1"></font>
<rt id="zqva1"></rt>
  • <tt id="zqva1"></tt>
    <cite id="zqva1"></cite>

    <cite id="zqva1"><noscript id="zqva1"></noscript></cite>
      <rp id="zqva1"><meter id="zqva1"></meter></rp>

        <cite id="zqva1"></cite>
          <b id="zqva1"></b>
          <rp id="zqva1"></rp>
          <cite id="zqva1"></cite>

          <rt id="zqva1"></rt>

        1. <rp id="zqva1"></rp>

          js函數防抖與函數節流

          時間:?2017-12-12閱讀:?825標簽:?js知識

          概念

          有一些瀏覽器事件可以在很短的事件內快速觸發多次,例如 調整窗口大小 或 向下滾動 頁面。例如,如果將事件監聽器綁定到窗口滾動事件上,并且用戶繼續非常快速地向下滾動頁面,你的事件可能會在3秒的范圍內被觸發數千次。這可能會導致一些嚴重的性能問題,

          如果在面試中討論構建應用程序和事件,如滾動、窗口調整大小,或鍵盤按下的事件時,一定要提及函數防抖動和函數節流來提升頁面速度和性能。

          直接綁定函數到scroll事件是非常錯誤的決定,當用戶滾動頁面時,頁面可能會變得非常慢甚至未響應。而函數防抖和函數節流是解決這個問題的一種方式,通過限制需要經過的事件,直至再次調用函數,在處理一些高頻率觸發的 DOM 事件的時候,它們都能極大提高


          函數防抖

          如果一個事件被頻繁觸發多次,并且觸發的時間間隔過短,則防抖函數可以使得對應的事件處理函數只執行一次 

          // debounce函數用來包裹我們的事件處理方法
          function debounce(fn, delay){
              // 持久化一個定時器
              let timer = null
              
              // 閉包函數可以訪問timer
              return function(){
                  // 通過 this 和 arguments 獲得函數的作用域和參數
                  let context = this
                  let args = arguments
                  // 如果事件被觸發,清除timer并重新開始計時
                  clearTimeout(timer)
                  timer = setTimeout(function() {
                      fn.apply(context, args)
                  }, delay)
              }
          }
          
          function foo(){
              console.log('You are scrolling!')
          }
          
          document.addEventListener('scroll', debounce(foo, 50));


          函數節流

          throttle 的概念理解稍微容易一些,如果一個事件被頻繁觸發多次,節流函數可以按照固定頻率去執行對應的事件處理方法 

          function throttle(fn, threshold){
              var last
              
              var timer
              
              threshold || (threshold = 250)
              
              return function(){
                  let context = this
                  let args = arguments
                  
                  var now = +new Date()
                  
                  if(last&&now<last+threshold){
                      clearTimeout(timer)
                      
                      timer = setTimeout(function(){
                          last = now
                          fn.apply(context, args)
                      },threshold)
                  }else {
                      last = now
                      fn.apply(context, args)
                  }
              }
          }


           

           

          吐血推薦

          1.站長廣告聯盟: 整理了目前主流的廣告聯盟平臺,如果你有流量,可以作為參考選擇適合你的平臺點擊進入...

          2.休閑娛樂: 直播/交友    優惠券領取   網頁游戲   H5游戲

          鏈接: http://www.modern-decoration.com.cn/article/detial/241

          javascript中什么是句柄?

          一個句柄是指使用的一個唯一的整數值,即一個4字節(64位程序中為8字節)長的數值,來標識應用程序中的不同對象和同類中的不同的實例。

          javascript不可變性是什么?

          不可變性即某個變量在進行了某個操作之后,其本身沒有發生變化,比如對于字符串而言,對字符串的任何操作都會改變字符串本身的值,而是在字符串的基礎上復制出來一個然后再改變,這樣我們就說是不可變的

          為什么javascript不起作用?

          JavaScript是一種屬于網絡的腳本語言,已經被廣泛用于Web應用開發,常用來為網頁添加各式各樣的動態功能,為用戶提供更流暢美觀的瀏覽效果。通常JavaScript腳本是通過嵌入在HTML中來實現自身的功能的。

          javascript怎么判斷按鈕被點擊?

          JavaScript可以通過Event對象的target事件或srcElement(IE瀏覽器支持)來判斷按鈕是否被點擊。Event對象代表事件的狀態,比如事件在其中發生的元素、鍵盤按鍵的狀態、鼠標的位置、鼠標按鈕的狀態。

          javascript由幾部分組成?

          JavaScript有三部分組成。分別為核心(ECMAScript) 、文檔對象模型(DOM)、瀏覽器對象模型(BOM)。這三部分分別描述了該語言的語法和基本對象、處理網頁內容的方法和接口、與瀏覽器進行交互的方法和接口。

          Js輸出方式有哪些?

          在編寫JavaScript代碼的時候, 一定要記住每一句代碼后面都需要添加一個分號, 并且這個分號必須是英文的分號,我們會發現有時候不寫分號程序也能夠運行, 這里并不是因為不需要分號, 而是瀏覽器自動幫助我們添加了分號

          7個常見的 JavaScript 測驗及解答

          我相信學習新事物并評估我們所知的東西對自己的進步非常有用,可以避免了我們覺得自己的知識過時的情況。在本文中,我將介紹一些常見的 JavaScript 知識。請享用!

          Js中constructor指向問題

          首先用一個例子指出來constructor存在形式。由上面的代碼我們總結出結論1:上面的代碼在控制臺可以看出constructor是指向構造器Fruit的引用。這個地方就有點奇怪了。這個constructor到底指向的是那個實例的構造器?

          javascript難點是什么?

          javascript難點是什么?下面本篇文章就來給大家介紹一下10個JavaScript難點,感興趣的小伙伴們可以參考一下,希望對大家有所幫助。立即執行函數,即Immediately Invoked Function Expression (IIFE),正如它的名字

          Js如何獲取ul中li的個數?

          javascript如何獲取ul中li的個數?下面本篇文章就來給大家介紹一下使用javascript獲取ul中li個數的方法,希望對大家有所幫助。

          fly63.com版權所有,內容以共享、參考、研究為目的,不存在任何商業目的。其版權屬原作者所有,如有侵權,請與小編聯系!情況屬實本人將予以刪除!

          文章投稿關于web前端網站點搜索站長推薦網站地圖站長QQ:522607023

          小程序專欄: 土味情話心理測試腦筋急轉彎幽默笑話段子句子語錄成語大全

          国产精品高清视频免费 - 视频 - 在线观看 - 影视资讯 - 唯爱网