<strike id="g3zqm"></strike>

      <cite id="g3zqm"></cite>

        <tr id="g3zqm"><center id="g3zqm"></center></tr>
        <pre id="g3zqm"><sup id="g3zqm"></sup></pre>
        <li id="g3zqm"></li>
      1. 少妇高潮激情一区二区三,免费av深夜在线观看,亚洲狼人久久伊人久久伊,久久精品人人做人人爽电影蜜月,黄色特级片一区二区三区,欧美日韩在线亚洲二区综二,极品少妇无套内射视频,日本极品少妇videossexhd

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

        2019-5-25    seo達人

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

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

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

        這樣做的不足也很明顯:

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

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

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

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

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

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

        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))

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

        *第二種方案: *

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

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

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

        日歷

        鏈接

        個人資料

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

        存檔

        主站蜘蛛池模板: 一区二区国产精品精华液| 97色婷婷成人综合在线观看| 波多野无码中文字幕av专区| 亚洲成在人线AⅤ中文字幕| 国产探花在线精品一区二区| 洛扎县| 中文乱码人妻系列一区| 国产94在线 | 亚洲| 亚洲线精品一区二区三区| 亚洲综合无码AV| 99久久亚洲精品影院| 久久综合结合久久狠狠狠97色| 久久天天躁狠狠躁夜夜躁| 亚洲精品亚洲人成人网| 国产熟女AV| 亚洲熟妇国产熟妇肥婆| 亚洲一区二区三区四区-av黄色在线播放-成人AV | 亚洲熟女1P| 亚洲av无码乱码在线观看野外| 欧美老少配性行为| 中文字幕乱码日本道在线观看| AV色色色| 丁香五月亭亭| 三级片视频网站| 国产麻豆9l精品三级站| 国产精品一码在线播放| 亚洲欧美中文字幕日韩一区二区| 免费无码高H视频在线观看| 精品人妻一区二区三区四区视频不卡| 久久久久亚洲AV成人无码网站| 在线亚洲+欧美+日本专区| 亚洲 欧美 综合 在线 精品| 久久亚洲国产成人精品性色| 国产亚洲色视频在线| 福利视频网| 成人无码区免费AV片| 久久香蕉超碰97国产精品| 一区二区三区乱码国产在线| 久久不见久久见www日本| 99在线国内在线视频22| 多毛老熟女|