欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

VUE前端實(shí)現(xiàn)防抖節(jié)流Lodash工具庫(kù)舉例詳解

 更新時(shí)間:2025年01月23日 09:08:56   作者:百事老餅干  
這篇文章主要介紹了Lodash庫(kù)和自定義防抖、節(jié)流函數(shù)的使用方法,包括它們的定義、應(yīng)用示例及應(yīng)用場(chǎng)景文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下

方法一:采用Lodash工具庫(kù)

Lodash 是一個(gè)一致性、模塊化、高性能的 JavaScript 實(shí)用工具庫(kù)。

(1)采用終端導(dǎo)入Lodash庫(kù)

$ npm i -g npm
$ npm i --save lodash

(2)應(yīng)用

示例:搜索框輸入防抖

在這個(gè)示例中,我們希望用戶在輸入框中停止輸入 500 毫秒后才執(zhí)行搜索操作,避免頻繁請(qǐng)求.

<input type="text" id="search" placeholder="Search...">

<script src="https://cdn.jsdelivr.net/npm/lodash@4.17.21/lodash.min.js"></script>
<script>
  // 假設(shè)這是一個(gè)執(zhí)行搜索操作的函數(shù)
  function performSearch(query) {
    console.log('Searching for:', query);
    // 這里可以發(fā)送 ajax 請(qǐng)求進(jìn)行搜索
  }

  // 使用 lodash 的 debounce 函數(shù)
  const debouncedSearch = _.debounce(function(event) {
    performSearch(event.target.value);
  }, 500);  // 500ms 的防抖時(shí)間

  // 監(jiān)聽輸入框的輸入事件
  document.getElementById('search').addEventListener('input', debouncedSearch);
</script>

示例:滾動(dòng)事件節(jié)流

在這個(gè)示例中,我們希望當(dāng)用戶滾動(dòng)頁(yè)面時(shí),每隔 1 秒才記錄一次滾動(dòng)事件,避免頻繁觸發(fā)回調(diào)函數(shù)。

<div style="height: 2000px;">Scroll down to see the effect</div>
<!-- 導(dǎo)入 throttle 函數(shù)-->
<script src="https://cdn.jsdelivr.net/npm/lodash@4.17.21/lodash.min.js"></script>
<script>
    // 這是一個(gè)處理滾動(dòng)事件的函數(shù)
    function handleScroll() {
        console.log('Scroll event detected at:', new Date().toLocaleTimeString());
    }

    // 使用 lodash 的 throttle 函數(shù),每隔 1 秒最多觸發(fā)一次
    const throttledScroll = _.throttle(handleScroll, 1000);

    // 監(jiān)聽滾動(dòng)事件
    window.addEventListener('scroll', throttledScroll);
</script>
  • 解釋
    • 當(dāng)用戶滾動(dòng)頁(yè)面時(shí),throttledScroll 函數(shù)會(huì)在 1 秒內(nèi)最多觸發(fā)一次,避免滾動(dòng)時(shí)回調(diào)函數(shù)被頻繁調(diào)用。
    • 這優(yōu)化了頁(yè)面滾動(dòng)的性能,特別是在回調(diào)函數(shù)較為復(fù)雜時(shí)。

示例:結(jié)合 leading 和 trailing 選項(xiàng)

假設(shè)我們希望在用戶第一次觸發(fā)事件時(shí)立即執(zhí)行函數(shù),并在停止觸發(fā) 1 秒后再次執(zhí)行。

<input type="text" id="input-field" placeholder="Type something...">

<script src="https://cdn.jsdelivr.net/npm/lodash@4.17.21/lodash.min.js"></script>
<script>
    // 假設(shè)這是一個(gè)處理輸入的函數(shù)
    function handleInput(value) {
        console.log('Input value processed:', value);
    }

    // 使用 debounce 函數(shù),并配置 leading 和 trailing 選項(xiàng)
    const debouncedInput = _.debounce(function(event) {
        handleInput(event.target.value);
    }, 1000, { leading: true, trailing: true });

    // 監(jiān)聽輸入框的輸入事件
    document.getElementById('input-field').addEventListener('input', debouncedInput);
</script>

方法二:自定義防抖、節(jié)流函數(shù)

(1)在utils文件夾下創(chuàng)建lodash.ts文件,里面定義防抖節(jié)流函數(shù)

// 防抖函數(shù)
export function debounce(fn: Function, delay: number) {
  let timer: ReturnType<typeof setTimeout> | null = null;

  return function (this: any, ...args: any[]) {
    // 清除上一個(gè)定時(shí)器
    if (timer) {
      clearTimeout(timer);
    }

    // 設(shè)置新的定時(shí)器
    timer = setTimeout(() => {
      fn.apply(this, args); // 使用apply確保this和參數(shù)正確傳遞
    }, delay);
  };
}

  
// 節(jié)流函數(shù)
export function throttle(fn: Function, delay: number) {
  let lastTime = 0;

  return function (this: any, ...args: any[]) {
    const now = Date.now();

    // 如果距離上次執(zhí)行時(shí)間已超過指定時(shí)間間隔,則執(zhí)行函數(shù)
    if (now - lastTime >= delay) {
      lastTime = now;  // 更新上次執(zhí)行時(shí)間
      fn.apply(this, args);
    }
  };
}

(2)應(yīng)用

防抖

  • 方式一:
<template>
  <div>
    <input v-model="searchText" placeholder="輸入搜索內(nèi)容" />
    <button @click="handleSubmit">提交</button>
  </div>
</template>

<script lang="ts" setup>
import { ref } from 'vue';
import { debounce } from '@/utils/debounce';  // 引入自己寫的防抖函數(shù)

// 1. 聲明響應(yīng)式數(shù)據(jù)
const searchText = ref<string>('');

// 2. 防抖函數(shù),延遲1000毫秒執(zhí)行提交操作
const submitForm = (val: string) => {
  console.log('提交的搜索值:', val);
  // 在這里執(zhí)行提交操作
};

// 3. 使用防抖函數(shù)包裝提交操作
const handleSubmit = debounce(() => {
  submitForm(searchText.value);  // 使用當(dāng)前輸入的值執(zhí)行提交操作
}, 1000); // 防抖延遲設(shè)置為1000毫秒

</script>
  • 方式二:
<template>
  <div>
    <input v-model="searchText" placeholder="輸入搜索內(nèi)容" />
    <button @click="submitForm(searchText)">提交</button>
  </div>
</template>

<script lang="ts" setup>
import { ref } from 'vue';
import { debounce } from '@/utils/debounce';  // 引入自己寫的防抖函數(shù)

// 1. 聲明響應(yīng)式數(shù)據(jù)
const searchText = ref<string>('');

// 2. 定義提交表單操作
const submitForm = debounce((val: string) => {
  console.log('提交的搜索值:', val);
  // 在這里執(zhí)行提交操作
}, 1000);  // 防抖延遲設(shè)置為1000毫秒

</script>

節(jié)流

<template>
  <div @scroll="handleScroll" style="height: 300px; overflow-y: scroll;">
    <!-- 模擬內(nèi)容,超出容器高度以啟用滾動(dòng) -->
    <div style="height: 1000px;">滾動(dòng)內(nèi)容</div>
  </div>
</template>

<script lang="ts" setup>
import { throttle } from './debounce';  // 引入節(jié)流函數(shù)

// 1. 定義滾動(dòng)事件處理函數(shù)(節(jié)流)
const handleScroll = throttle(() => {
  console.log('滾動(dòng)事件觸發(fā)');
  // 在這里處理滾動(dòng)事件,例如加載更多內(nèi)容
}, 200);  // 每200毫秒只執(zhí)行一次

</script>
<template>
  <div @scroll="handleScroll" style="height: 300px; overflow-y: scroll;">
    <!-- 模擬內(nèi)容,超出容器高度以啟用滾動(dòng) -->
    <div style="height: 1000px;">滾動(dòng)內(nèi)容</div>
  </div>
</template>

<script lang="ts" setup>
import { throttle } from './debounce';  // 引入節(jié)流函數(shù)

// 1. 定義滾動(dòng)事件處理函數(shù)(節(jié)流)
const handleScroll = throttle(() => {
  console.log('滾動(dòng)事件觸發(fā)');
  // 在這里處理滾動(dòng)事件,例如加載更多內(nèi)容
}, 200);  // 每200毫秒只執(zhí)行一次

</script>

應(yīng)用場(chǎng)景

防抖 (debounce):

手抖了。。。多點(diǎn)了好幾次,一定時(shí)間內(nèi)只執(zhí)行一次。(年紀(jì)大了手抖)

  • 功能:只有在用戶停止觸發(fā)事件一段時(shí)間后,才會(huì)執(zhí)行回調(diào)函數(shù)。
  • 應(yīng)用場(chǎng)景:輸入框搜索、窗口大小調(diào)整(resize)、表單提交等。

節(jié)流 (throttle):

好比點(diǎn)了兩次下拉刷新列表頁(yè)面,他不會(huì)馬上直接執(zhí)行兩次,是在你定義的一定時(shí)間間隔前提前,先執(zhí)行第一次在執(zhí)行第二次

  • 功能:在指定的時(shí)間間隔內(nèi),只執(zhí)行一次函數(shù)。如果觸發(fā)頻繁,函數(shù)執(zhí)行會(huì)被限制在每個(gè)時(shí)間間隔內(nèi)最多執(zhí)行一次。
  • 應(yīng)用場(chǎng)景:滾動(dòng)事件、鼠標(biāo)移動(dòng)事件、resize 事件等。

附:安裝和引入問題

問題描述: 新手在使用 Vue-lodash 時(shí),可能會(huì)遇到安裝和引入的問題。

解決步驟:

確保已經(jīng)正確安裝了 Vue 和 lodash。

使用 npm 或 yarn 安裝 Vue-lodash:

npm install --save vue-lodash lodash

yarn add vue-lodash lodash

在你的 Vue 項(xiàng)目中引入 Vue-lodash 和 lodash:

import Vue from 'vue';
import VueLodash from 'vue-lodash';
import lodash from 'lodash';

總結(jié) 

到此這篇關(guān)于VUE前端實(shí)現(xiàn)防抖節(jié)流Lodash工具庫(kù)的文章就介紹到這了,更多相關(guān)VUE前端防抖節(jié)流Lodash內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 基于Vue3+TypeScript實(shí)現(xiàn)鼠標(biāo)框選功能

    基于Vue3+TypeScript實(shí)現(xiàn)鼠標(biāo)框選功能

    這篇文章主要介紹了基于Vue3+TypeScript實(shí)現(xiàn)鼠標(biāo)框選功能,文中通過代碼示例給大家講解的非常纖細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-07-07
  • 解決el-date-picker 寬度溢出瀏覽器的問題

    解決el-date-picker 寬度溢出瀏覽器的問題

    這篇文章主要介紹了解決如何el-date-picker 寬度溢出瀏覽器問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-07-07
  • webpack項(xiàng)目中使用vite加速的兼容模式詳解

    webpack項(xiàng)目中使用vite加速的兼容模式詳解

    這篇文章主要為大家介紹了webpack項(xiàng)目中使用vite加速的兼容模式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • vant IndexBar實(shí)現(xiàn)的城市列表的示例代碼

    vant IndexBar實(shí)現(xiàn)的城市列表的示例代碼

    這篇文章主要介紹了vant IndexBar實(shí)現(xiàn)的城市列表的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 用vue 實(shí)現(xiàn)手機(jī)觸屏滑動(dòng)功能

    用vue 實(shí)現(xiàn)手機(jī)觸屏滑動(dòng)功能

    這篇文章主要介紹了用vue 實(shí)現(xiàn)手機(jī)觸屏滑動(dòng)的功能,文中通過示例代碼給大家介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • Vue安裝瀏覽器開發(fā)工具的步驟詳解

    Vue安裝瀏覽器開發(fā)工具的步驟詳解

    這篇文章主要介紹了Vue安裝瀏覽器開發(fā)工具步驟詳解,本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • Vue.prototype詳解及使用方式

    Vue.prototype詳解及使用方式

    這篇文章主要介紹了Vue.prototype詳解及使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue-property-decorator的使用解讀

    vue-property-decorator的使用解讀

    這篇文章主要介紹了vue-property-decorator的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-06-06
  • vue實(shí)現(xiàn)帶縮略圖的輪播圖效果

    vue實(shí)現(xiàn)帶縮略圖的輪播圖效果

    這篇文章主要為大家詳細(xì)介紹了如何使用vue實(shí)現(xiàn)帶縮略圖的輪播圖效果,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,有需要的可以參考下
    2024-02-02
  • 如何用vue封裝axios請(qǐng)求

    如何用vue封裝axios請(qǐng)求

    對(duì)axios進(jìn)行封裝以及將API接口按業(yè)務(wù)模塊統(tǒng)一管理,有助于我們簡(jiǎn)化代碼,方便后期維護(hù)。本文介紹了如何用vue封裝axios請(qǐng)求,感興趣的同學(xué),可以參考下。
    2021-06-06

最新評(píng)論