国产精品美女久久久浪潮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.shtzxx.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務

        日歷

        鏈接

        個人資料

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

        存檔

        主站蜘蛛池模板: 亚洲国产精品久久电影欧美| 国产亚洲综合区成人国产系列| 玛纳斯县| 丰满少妇熟乱xxxxx视频| 婷婷五月综合丁香在线| 亚洲爆乳无码一区二区三区| 修水县| 小12箩利洗澡无码视频网站| 人妻无码中文字幕| 欧美国产日韩a在线视频| 国产美女亚洲精品久久久毛片| 欧美性猛交xxxx乱大交3| 国产色av| 久久综合亚洲欧美成人| 久久久精品人妻无码专区不卡 | 湛江市| 亚洲精品456在线播放| 夜夜添无码试看一区二区三区| 公粗挺进了我的密道在线播放| 久久亚洲av午夜福利精品一区| 野花电影免费观看| 亚洲国产欧美日韩另类| 天堂中文最新版在线官网在线| 丰满少妇熟乱xxxxx视频| 国产www.色| 少妇人妻互换不带套| 国产成人精品久久一区二区三区 | 精品人人妻人人澡人人爽人人| 欧美精品videossex少妇| 少妇被粗大猛进进出出| 久久久亚洲欧洲日产国码aⅴ| 电白县| 国精产品一品二品国精破解| 邢台县| 好姑娘免费中文在线观看| 韩国三级伦在线观看久| 国产精品久久久久影院嫩草| 人人av| 日本高清视频网站www| 和尚伦流澡到高潮h在线观看| 国精产品一品二品国精破解|