<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

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

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

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

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

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

          這樣做的不足也很明顯:

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

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

          如何解決以上兩種問(wèn)題呢? 有兩種解決方案

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

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

          首先定義一個(gè)定時(shí)器timer
          監(jiān)聽(tīng)輸入框的keyup事件,在回調(diào)函數(shù)里先清除timer,這一步總能保證在用戶停止輸入1秒后執(zhí)行最后一個(gè)timer。如果用戶輸入的間隔小于1秒就不會(huì)執(zhí)行timer
          這么寫(xiě)似乎不太抽象,而且定義了一個(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ù)中寫(xiě)我們的處理邏輯就可以了。而且沒(méi)有了全局變量,避免了全局污染的可能!!

          *第二種方案: *

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

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

          藍(lán)藍(lán)設(shè)計(jì)m.sdgs6788.com )是一家專注而深入的界面設(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è)人資料

          存檔

          久久精品成人免费网站| 精品综合久久久久久88小说| 中文字幕乱码久久午夜| 72种姿势欧美久久久久大黄蕉| 久久精品九九亚洲精品天堂| 久久影院亚洲一区| 久久综合国产乱子伦精品免费| 办公室久久精品| 亚洲午夜久久久久久久久久 | 久久电影网| 午夜精品久久久久久毛片| 99精品久久久久久久婷婷| 亚洲AV无码久久精品蜜桃| 热久久国产精品| 久久精品国产亚洲AV电影| 伊人精品久久久久7777| 国产精品免费久久久久电影网| 久久久久亚洲av成人网人人软件| 久久久久久久尹人综合网亚洲 | 狠狠色丁香婷婷久久综合 | 久久久久99这里有精品10| 精品久久久久久中文字幕| 性欧美大战久久久久久久久| 久久久久无码中| 99久久精品免费观看国产| 久久国产乱子精品免费女| 国产69精品久久久久久人妻精品| 久久影院久久香蕉国产线看观看| 91亚洲国产成人久久精品| 国产精品久久久天天影视| 99精品国产在热久久无毒不卡 | 久久久久九国产精品| 精品久久久久久无码免费| 亚洲成色999久久网站| 99久久成人国产精品免费| 久久精品蜜芽亚洲国产AV| 久久久亚洲欧洲日产国码aⅴ| 新狼窝色AV性久久久久久| 久久青青草原精品国产| 国产情侣久久久久aⅴ免费| 精品熟女少妇a∨免费久久|