• <center id="sm46c"></center>
  • <dfn id="sm46c"></dfn>
  • <strike id="sm46c"></strike>
  • <cite id="sm46c"><source id="sm46c"></source></cite>
    • <strike id="sm46c"><source id="sm46c"></source></strike>
      <option id="sm46c"></option>
      国产精品天天看天天狠,女高中生强奷系列在线播放,久久无码免费的a毛片大全,国产日韩综合av在线,亚洲国产中文综合专区在,特殊重囗味sm在线观看无码,中文字幕一区二区三区四区在线,无码任你躁久久久久久老妇蜜桃

      根據(jù)輸入實(shí)時(shí)發(fā)送請(qǐng)求(防抖函數(shù))

      2019-5-25    seo達(dá)人

      如果您想訂閱本博客內(nèi)容,每天自動(dòng)發(fā)到您的郵箱中, 請(qǐng)點(diǎn)這里

      有這樣一種常見的需求:有一個(gè)搜索框,需要根據(jù)用戶的輸入進(jìn)行實(shí)時(shí)的查詢。也就是說用戶每輸入一個(gè)字符就要發(fā)送一次請(qǐng)求。

      想到的做法是監(jiān)聽輸入框的keyup時(shí)間然后在回調(diào)里發(fā)送異步請(qǐng)求。

      這樣做的不足也很明顯:

      其實(shí)我們并不需要用戶每次輸入時(shí)都發(fā)送請(qǐng)求,這樣會(huì)給服務(wù)器造成不必要的壓力。

      因?yàn)榘l(fā)送的是異步請(qǐng)求,有可能查詢的結(jié)果和最后輸入的內(nèi)容并不匹配。

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

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

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

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

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

      這樣是不是復(fù)用性更高,我們只需要在handle函數(shù)中寫我們的處理邏輯就可以了。而且沒有了全局變量,避免了全局污染的可能?。?br />
      *第二種方案: *

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

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

      藍(lán)藍(lán)設(shè)計(jì)www.li-bodun.cn )是一家專注而深入的界面設(shè)計(jì)公司,為期望卓越的國(guó)內(nèi)外企業(yè)提供卓越的UI界面設(shè)計(jì)、BS界面設(shè)計(jì) 、 cs界面設(shè)計(jì) 、 ipad界面設(shè)計(jì) 、 包裝設(shè)計(jì) 、 圖標(biāo)定制 、 用戶體驗(yàn) 、交互設(shè)計(jì)、 網(wǎng)站建設(shè) 、平面設(shè)計(jì)服務(wù)

      日歷

      鏈接

      個(gè)人資料

      存檔

      主站蜘蛛池模板: 国产午夜成人久久无码一区二区 | 国产91成人亚洲综合在线| 色久悠悠婷婷综合在线亚洲| 国产精品一区二区韩国AV| 激情在线一区二区三区视频| 国产亚洲精品字幕在线观看| 国产成人午夜福利精品| 国产自产精品露脸刺激91在线| 精品国产自线午夜福利| 日本护士毛茸茸高潮| 人妻精品国产一区二区| 亚洲色偷偷偷鲁精品| 久久频这里精品99香蕉久网址| 熟女人妻水多爽中文字幕| 亚洲精品日本久久一区二区三区| 无码av无码一区二区桃花岛| 国产青草视频在线观看| 成人AV无码一区二区三区| 国产黄色av一区二区三区| 98日韩精品人妻一二区| 亚洲香蕉网久久综合影视| 国产不卡av一区二区| 青青青国产精品国产精品美女| AV永久天堂网| 欧美区日韩区| 国产高清一区二区三区视频| 国产精品xxx在线| 中国性欧美videofree精品 | 国产自在自线午夜精品| 国产亚洲无日韩乱码| 国产农村乱对白刺激视频| 亚洲国产精品久久久久婷婷老年| 天天爽夜夜爱| 亚洲美女厕所偷拍美女尿尿| 草草浮力影院| 国产成人精品怡红院在线观看| 日本成人不卡视频| 色综合热无码热国产| 免费看的日韩精品黄色片| 无码日韩精品一区二区人妻| 国产精品久久久久久影视不卡|