国产精品美女久久久浪潮AV,国产精品三级一二三区,久久精品国产一区二区小说 ,依依成人影视国产精品,全部无卡免费的毛片在线看,日本一区二区三深夜不卡,国产精品女同一区二区久久,国产精品夜色一区二区三区

        根據(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ù)中寫我們的處理邏輯就可以了。而且沒有了全局變量,避免了全局污染的可能!!

        *第二種方案: *

        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.shtzxx.cn )是一家專注而深入的界面設(shè)計(jì)公司,為期望卓越的國內(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è)人資料

        存檔

        主站蜘蛛池模板: 久久久噜噜噜久久熟女色| 两个人免费观看日本的完整版| 成人无码网www在线观看| 少妇aaa级久久久无码精品片| 又粗又爽高潮午夜免费视频| 国产l精品国产亚洲区在线观看| 最新欧美精品一区二区三区| 日日夜夜撸| 最近中文字幕高清| 老太脱裤子让老头玩xxxxx| 苗栗市| 北辰区| 免费ā片在线观看| 天堂www在线资源天堂在线| 五级黄高潮片90分钟视频| 麻豆精产国品一二三产区| 比如县| 国产女人高潮叫床视频| 精品乱码久久久久久中文字幕| 厨房掀裙子从后面进啪啪| cijilu在线视频| 秀山| 热re99久久精品国99热| 中文字字幕人妻中文| 强开小雪的嫩苞又嫩又紧| 十七岁免费观看完整版| 性xxxx视频播放免费| 亚洲人成电影在线天堂色| 性激烈的欧美三级视频| 国产精品免费观看久久| 借妻中文字幕高清| 成年免费a级毛片免费看| 边做边爱免费视频| 晴隆县| 国产精品久久久久久52avav| 无码人妻一区二区三区精品视频| 精品一区二区三区波多野结衣| 亚洲无线码一区二区三区| 99热在线精品国产观看| 国产精品久久久久久久久电影网| 日韩av一中美av一中文字慕|