在vue中使用防抖函數(shù)組件操作
初級(jí)
1、先寫好防抖函數(shù)
/**
* @desc 防抖函數(shù)
* @param {需要防抖的函數(shù)} func
* @param {延遲時(shí)間} wait
* @param {是否立即執(zhí)行} immediate
*/
export function debounce(func, wait, immediate) {
let timeout
return function(...args) {
let context = this
if (timeout) clearTimeout(timeout)
if (immediate) {
let callNow = !timeout
timeout = setTimeout(function() {
timeout = null
}, wait)
if (callNow) func.apply(context, args)
} else {
timeout = setTimeout(function() {
func.apply(context, args)
}, wait)
}
}
}
2、然后在要使用的組件里 import 進(jìn)來(lái)
import { debounce } from 'xxx'
export default {
data: {
return {
vm: this
}
},
methods: {
toDoSth: debounce((vm) => {
// 這里將當(dāng)前組件實(shí)例當(dāng)參數(shù)傳入
// 就可以使用實(shí)例中定義的一些屬性、方法
// 補(bǔ)充一下,這里如果換成非箭頭函數(shù)的寫法,也可以直接訪問實(shí)例。
},
500,
true
)
}
}
3、在組件方法中使用
template:
<div @click="toDoSth(vm)"></div>
高級(jí)
雖然上面的寫法已經(jīng)能解決問題了,但是總覺得不夠美觀。
在網(wǎng)上搜索一番,看到有個(gè)哥們將防抖封裝成一個(gè)組件,果然和我想的一樣。不過這哥們直接將上下文當(dāng)參數(shù)傳進(jìn)來(lái)了,比我把整個(gè)實(shí)例傳進(jìn)來(lái)高明,我在這個(gè)基礎(chǔ)上添加了 immediate 的功能,還有添加了默認(rèn)不傳 event 參數(shù)的情況處理。
debounce.js 文件:
import Vue from 'vue'
const debounce = (func, time, ctx, immediate) => {
let timer
const rtn = (...params) => {
clearTimeout(timer)
if (immediate) {
let callNow = !timer
timer = setTimeout(() => {
timer = null
}, time)
if (callNow) func.apply(ctx, params)
} else {
timer = setTimeout(() => {
func.apply(ctx, params)
}, time)
}
}
return rtn
}
Vue.component('Debounce', {
abstract: true,
props: ['time', 'events', 'immediate'],
created() {
this.eventKeys = this.events && this.events.split(',')
},
render() {
const vnode = this.$slots.default[0]
// 如果默認(rèn)沒有傳 events,則對(duì)所有綁定事件加上防抖
if (!this.eventKeys) {
this.eventKeys = Object.keys(vnode.data.on)
}
this.eventKeys.forEach(key => {
vnode.data.on[key] = debounce(
vnode.data.on[key],
this.time,
vnode,
this.immediate
)
})
return vnode
}
})
使用方式:
1、引入 debounce.js 文件
import 'xxx/debounce.js'
export default {
methods: {
toDoSth(e) {
// 這里正常寫就可以了
}
}
}
2、在模版里使用。
其中time為必選參數(shù)。 event 和 immediate 參數(shù)都是可選參數(shù)。
如果組件下有多個(gè)事件綁定,那么 event 可以自定義需要進(jìn)行防抖處理的事件。
如果需要立即執(zhí)行的話,可以將 immediate 參數(shù)設(shè)置為 true。
<Debounce :time="500" event="click" :immediate="true"> <button @click="toDoSth($event, 1)">click me</button> </Debounce>
到此就完成了一次 Debounce 組件的封裝。
補(bǔ)充知識(shí):vue防抖函數(shù),避免暴力點(diǎn)擊
1.vue項(xiàng)目/src/components/directive/clickAgain.js
import Vue from 'vue'
const clickAgain = Vue.directive('clickAgain',{
// 指令的定義
bind(el, binding, vnode, oldVnode) {
// 綁定this
let self = vnode.context;
el.onclick = function (e) {
if (self._is_click) {
return false;
}
/*執(zhí)行指令綁定的事件*/
self[binding.expression]()
self._is_click=true;
setTimeout(()=>{
self._is_click=false;
},2000)
};
}
});
export default clickAgain
2.在main.js 引入
import clickAgain from './components/directive/clickAgain.js'
/* 引入避免暴力雙擊點(diǎn)擊*/
Vue.use(clickAgain);
3.使用
<a-button key="submit" type="primary" :loading="false" v-clickAgain="handleOk"> 保存 </a-button>
以上這篇在vue中使用防抖函數(shù)組件操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue2實(shí)現(xiàn)directive自定義指令的封裝與全局注冊(cè)流程
自定義指令是對(duì)普通DOM元素進(jìn)行的底層操作,它是一種有效的的補(bǔ)充和擴(kuò)展,不僅可以用于定義任何的dom操作,并且是可以復(fù)用的,下面這篇文章主要給大家介紹了關(guān)于vue2實(shí)現(xiàn)directive自定義指令的封裝與全局注冊(cè)流程的相關(guān)資料,需要的朋友可以參考下2023-02-02
Vue3+Vite中不支持require的方式引入本地圖片的解決方案
這篇文章主要介紹了Vue3+Vite中不支持require的方式引入本地圖片的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
Vue3響應(yīng)式高階用法之shallowRef()的使用
在Vue3框架中,shallowRef()為開發(fā)者提供了細(xì)粒度的響應(yīng)式控制能力,特別適用于處理深層嵌套對(duì)象或需要部分響應(yīng)式的場(chǎng)景,本文就來(lái)詳細(xì)的介紹一下,感興趣的可以了解一下2024-09-09
詳解Vue項(xiàng)目編譯后部署在非網(wǎng)站根目錄的解決方案
這篇文章主要介紹了Vue項(xiàng)目編譯后部署在非網(wǎng)站根目錄的解決方案,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2018-04-04
Vue導(dǎo)入excel表,導(dǎo)入失敗的數(shù)據(jù)自動(dòng)下載
本文詳細(xì)講解了Vue導(dǎo)入excel表,導(dǎo)入失敗的數(shù)據(jù)自動(dòng)下載的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-11-11
vue利用vue meta info設(shè)置每個(gè)頁(yè)面的title與meta信息
這篇文章主要給大家介紹了關(guān)于vue如何利用vue meta info設(shè)置每個(gè)頁(yè)面的title與meta信息的相關(guān)資料,文中將實(shí)現(xiàn)的方法介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-10-10
在Vue中實(shí)現(xiàn)拖拽功能的實(shí)例
Vue實(shí)現(xiàn)拖拽功能的基本原理是監(jiān)聽鼠標(biāo)事件,實(shí)時(shí)更新拖拽元素的位置,最后在合適的時(shí)機(jī)停止拖拽并更新元素位置,在Vue中,我們可以通過綁定相關(guān)事件來(lái)實(shí)現(xiàn)這一功能2025-02-02

