1. <sup id="1kcns"></sup>

    2. <rt id="1kcns"><legend id="1kcns"></legend></rt>
      国产AV巨作丝袜秘书,国产精品久久香蕉免费播放,国产草草影院ccyycom,涩涩爱狼人亚洲一区在线,日本阿v片在线播放免费,国产精品一区二区三区蜜臀,精品一区二区三区在线观看l,av深夜免费在线观看

      根據輸入實時發送請求(防抖函數)

      2019-5-25    seo達人

      如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里

      有這樣一種常見的需求:有一個搜索框,需要根據用戶的輸入進行實時的查詢。也就是說用戶每輸入一個字符就要發送一次請求。

      想到的做法是監聽輸入框的keyup時間然后在回調里發送異步請求。

      這樣做的不足也很明顯:

      其實我們并不需要用戶每次輸入時都發送請求,這樣會給服務器造成不必要的壓力。

      因為發送的是異步請求,有可能查詢的結果和最后輸入的內容并不匹配。

      如何解決以上兩種問題呢? 有兩種解決方案

      首先我們規定當用戶停止輸入1秒(具體時間根據自己需求而定)后再根據輸入框的值發送請求。
      其次我們利用定時器來解決以上問題。
      第一種方案:直接看代碼吧

      vat timer
      $('.input').on('keyup', function(e) {
          clearTimeout(timer)
          timer = setTimeout(function() {
            // do something
          }, 1000)
      })

      首先定義一個定時器timer
      監聽輸入框的keyup事件,在回調函數里先清除timer,這一步總能保證在用戶停止輸入1秒后執行最后一個timer。如果用戶輸入的間隔小于1秒就不會執行timer
      這么寫似乎不太抽象,而且定義了一個全局變量timer,不友好!稍加改動一下:

      function debounce(func,delay){
          var timer
          return function(){
              clearTimeout(timer)
              var event = arguments[0]  // 獲取原生event參數
              timer = setTimeout(function(){
                  func(event)
              },delay)
          }
      }
      function handle(event){
          // do something 
      }
      $('.input').on('keyup', debounce(handle, 1000))

      這樣是不是復用性更高,我們只需要在handle函數中寫我們的處理邏輯就可以了。而且沒有了全局變量,避免了全局污染的可能!!

      *第二種方案: *

      var lastTime
      $('.input').on('keyup', function(e) {
          lastTime = e.timeStamp
          setTimeout(function() {
              console.log('timeout')
              if (lastTime == e.timeStamp) {
                  // do something
              }
          }, 1000)
      })

      首先定義一個時間戳來保存最后一次輸入的時間
      然后1秒后在定時器里判斷保存的時間戳和觸發事件的時間戳e.timeStamp是否相同,只要1秒內又輸入了內容,e.timeStamp就回變化。
      但是這種寫法有個弊端,用戶鍵入幾次就會執行幾次setTimeout,也就是說當用戶連續鍵入多個字符后,會有多個任務被推入待執行隊列,然后每隔1秒執行,只是在執行的時候判斷要不要發送異步請求,這種方式不會發送多余的異步請求,但是會執行多余的任務,這無疑浪費了性能。

      藍藍設計m.payeee.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務

      日歷

      鏈接

      個人資料

      藍藍設計的小編 http://m.payeee.cn

      存檔

      主站蜘蛛池模板: 亚洲中文一区二区av| 玩两个丰满老熟女久久网| 久久精品国产亚洲av忘忧草18| 日韩精品一二三黄色一级| 久久国产免费观看精品3| 亚洲欧美国产成人综合不卡| 亚洲精品乱码久久久久久蜜桃| 国产成AV人片在线观看天堂无码| 亚洲伊人久久大香线蕉| 国产v区| 亚洲高清无码人妻| 爱啪福利导航| h动态图男女啪啪27报gif| 欧美精品国产| 永久无码天堂网小说区| 亚洲a片成人无码久久精品色欲| 97人人看| 漂亮的保姆hd完整版免费韩国| 熟女福利导航| 麻豆国产成人AV在线播放| 日本五十路熟女在线视频| 美女国内精品自产拍在线播放| 日韩av第一页在线播放| 资源新版在线天堂偷自拍| 亚洲一区二区精品极品| 国产精品久久久久久无毒不卡| 人妻无码视频一区二区三区| 成在线人免费| 免费无码影视在线观看mov| 两性色午夜视频免费老司机| jizz国产| 日逼黄片| 国产一区二区三区欧美亚洲| 亚洲中文字幕成人无码| 国产日本一区二区三区久久| jizz免费| 激情综合网激情综合| 欧美日韩久久中文字幕| 国产午夜亚洲精品不卡网站| 国产精品18禁久久久久久白浆 | 在线观看亚洲不卡视频|