亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue防抖與節(jié)流的使用介紹

 更新時(shí)間:2022年12月21日 14:41:43   作者:和世界不一樣,那就不一樣!  
防抖和節(jié)流的作用都是防止函數(shù)多次調(diào)用,下面這篇文章主要給大家介紹了關(guān)于vue函數(shù)防抖與節(jié)流的正確使用方法,需要的朋友可以參考下

概念

1. 防抖

防抖策略(debounce):是當(dāng)事件被觸發(fā)后,延遲n秒后再執(zhí)行回調(diào)函數(shù),如果在這n秒內(nèi)事件被再次觸發(fā),則重新計(jì)時(shí).

好處是:它能夠保證用戶在頻繁觸發(fā)某些事件的時(shí)候,不會(huì)頻繁的執(zhí)行回調(diào),只會(huì)被執(zhí)行一次.

防抖的概念:如果有人進(jìn)電梯(觸發(fā)事件),那電梯將在10秒鐘后出發(fā)(執(zhí)行事件監(jiān)聽器),這時(shí)如果又有人進(jìn)電梯了(在10秒內(nèi)再次觸發(fā)該事件),我們又得等10秒再出發(fā)(重新計(jì)時(shí))。

防抖的應(yīng)用場(chǎng)景::

用戶在輸入框連續(xù)輸入一串字符時(shí),可以通過防抖策略,只在輸入完后,才執(zhí)行查詢的請(qǐng)求,這樣可以有效減少請(qǐng)求次數(shù),節(jié)約請(qǐng)求資源.

2. 節(jié)流策略

節(jié)流策略(throttle):,可以減少一段時(shí)間內(nèi)事件的觸發(fā)頻率.

節(jié)流閥的概念:

高鐵的衛(wèi)生間是否被占用,由紅綠燈控制,假設(shè)一個(gè)每個(gè)人上洗手間要五分鐘,則五分鐘之內(nèi)別人不可以使用,上一個(gè)使用完畢之后,將紅燈設(shè)置為綠燈,表示下一個(gè)人可以使用了.下一個(gè)人在使用洗手間時(shí)需要先判斷控制燈是否為綠色,來知曉洗手間是否可用.

–節(jié)流閥為空,表示可以執(zhí)行下一次操作,不為空,表示不能使用下次操作.

–當(dāng)前操作執(zhí)行完之后要將節(jié)流閥重置為空,表示可以執(zhí)行下次操作了.

–每次執(zhí)行操作之前,先判斷節(jié)流閥是否為空

節(jié)流策略的應(yīng)用場(chǎng)景:

1)鼠標(biāo)不斷觸發(fā)某事件時(shí),如點(diǎn)擊,只在單位事件內(nèi)觸發(fā)一次.

2)懶加載時(shí)要監(jiān)聽計(jì)算滾動(dòng)條的位置,但不必要每次滑動(dòng)都觸發(fā),可以降低計(jì)算頻率,而不必要浪費(fèi)CPU資源.

Vue中的使用

項(xiàng)目中新建一個(gè)throttleDebounce.js文件

export default {
// 防抖
debounce: function (fn, t) {
    let delay = t || 500;
    let timer;
    return function () {
      let th = this;
      let args = arguments;
      if (timer) {
        clearTimeout(timer);
      }
      timer = setTimeout(function () {
        timer = null;
        fn.apply(th, args);
      }, delay);
    }
  },
  // 節(jié)流
  throttle: function (fn, t) {
    let last;
    let timer;
    let interval = t || 500;
    return function () {
      let th = this;
      let args = arguments;
      let now = +new Date();
      if (last && now - last < interval) {
        clearTimeout(timer);
        timer = setTimeout(function () {
          last = now;
          fn.apply(th, args);
        }, interval);
      } else {
        last = now;
        fn.apply(th, args);
      }
    }
  }
}

FileConvert.vue文件

引入

import throttleDebounce from '@/utils/throttleDebounce.js'
// convertRes  是el-button綁定的點(diǎn)擊事件
methods:{
convertRes: throttleDebounce.throttle(function() {
      //  需要節(jié)流的事件,我這里是接口的調(diào)取
      this.convertResFinal()  
    }, 500),
//  節(jié)流的事件
convertResFinal() {
      this.$refs['form'].validate(async valid => {
        if (valid) {
          this.hexBtnLoading = true
          const params = {
            arch: this.form.arch,
            addr: this.form.addr,
            hexdump: this.form.hexdump
          }
          try {
            const res = await getVexConvertRes(params)
            if (res.code === 200) {
              
            }
          } catch (error) {
          }
        }
      })
    },
}

到此這篇關(guān)于Vue防抖與節(jié)流的使用介紹的文章就介紹到這了,更多相關(guān)Vue防抖與節(jié)流內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論