• <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <small id="ggggg"></small> <sup id="ggggg"></sup>
    <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <tfoot id="ggggg"></tfoot>
  • <nav id="ggggg"><cite id="ggggg"></cite></nav>
    <nav id="ggggg"></nav>
    成人黃色A片免费看三更小说,精品人妻av区波多野结衣,亚洲第一极品精品无码,欧美综合区自拍亚洲综合,久久99青青精品免费观看,中文字幕在线中字日韩 ,亚洲国产精品18久久久久久,黄色在线免费观看

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

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

    日歷

    鏈接

    個人資料

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

    存檔

    主站蜘蛛池模板: 无码中文字幕人妻在线一区| 国产91丝袜在线播放动漫 | 99精品在线视频观看| 国产精品久久久久久99人妻精品| 人妻少妇被猛烈进入中文字幕| 国产成人亚洲综合小说区| 亚洲国产成人久久综合一区| 亚洲色成人一区二区三区| 福利二区| 91色老久久精品偷偷蜜臀| 成人无码精品免费视频在线观看| 一级毛片免费不卡在线视频| 在线亚洲视频网站www色| 亚洲永久字幕精品免费| 人妻少妇偷人无码视频| 兰考县| 香蕉97超级碰碰碰免费公| 亚洲av综合亚洲精品| 国产精品无码a∨精品影院app| 精品无套挺进少妇内谢| 精品一区二区三区在线视频| 亚洲精品97福利在线| 被公侵犯的漂亮人妻中文字幕| 91久久国产情侣真实对白| 国产成人99久久亚洲综合精品| 免费无码又爽又刺激网站直播| 丰满亚洲大尺度无码无码专线| 国产伦精品一区二区三区视频优播| 景德镇市| 麻豆精品久久久久久久99蜜桃| 色欲AV无码一区二区人妻| 91美女视频在线观看| 免费无码高潮流白浆视频| 日韩黄色精品中文视频| 亭亭五月丁香| 污网站在线免费观看| 亚洲日韩AV秘 无码一区二区| 五月天丁香网| 国产高清在线精品一区导航| 国产午夜视频在线观看| 永春县|