日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

在vue中使用防抖函數組件操作

瀏覽:22日期:2022-12-28 09:13:58

初級

1、先寫好防抖函數

/** * @desc 防抖函數 * @param {需要防抖的函數} func * @param {延遲時間} wait * @param {是否立即執行} 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 進來

import { debounce } from ’xxx’export default { data: { return { vm: this } }, methods: { toDoSth: debounce((vm) => { // 這里將當前組件實例當參數傳入 // 就可以使用實例中定義的一些屬性、方法 // 補充一下,這里如果換成非箭頭函數的寫法,也可以直接訪問實例。 }, 500, true ) }}

3、在組件方法中使用

template:

<div @click='toDoSth(vm)'></div>

高級

雖然上面的寫法已經能解決問題了,但是總覺得不夠美觀。

在網上搜索一番,看到有個哥們將防抖封裝成一個組件,果然和我想的一樣。不過這哥們直接將上下文當參數傳進來了,比我把整個實例傳進來高明,我在這個基礎上添加了 immediate 的功能,還有添加了默認不傳 event 參數的情況處理。

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] // 如果默認沒有傳 events,則對所有綁定事件加上防抖 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為必選參數。 event 和 immediate 參數都是可選參數。

如果組件下有多個事件綁定,那么 event 可以自定義需要進行防抖處理的事件。

如果需要立即執行的話,可以將 immediate 參數設置為 true。

<Debounce :time='500' event='click' :immediate='true'> <button @click='toDoSth($event, 1)'>click me</button></Debounce>

到此就完成了一次 Debounce 組件的封裝。

補充知識:vue防抖函數,避免暴力點擊

1.vue項目/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; } /*執行指令綁定的事件*/ 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’

/* 引入避免暴力雙擊點擊*/

Vue.use(clickAgain);

3.使用

<a-button key='submit' type='primary' :loading='false' v-clickAgain='handleOk'> 保存</a-button>

以上這篇在vue中使用防抖函數組件操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
午夜在线视频观看日韩17c| 免费久久精品视频| 欧美日本二区| 中文国产一区| 亚洲一区国产| 午夜在线视频一区二区区别| 亚洲成人一区| 五月天激情综合网| 国产精品外国| 中文字幕亚洲在线观看| 日韩一区二区三免费高清在线观看 | 精品免费av一区二区三区| 欧美日韩中文| 日韩成人在线看| 国产毛片久久久| 欧美aaaaaa午夜精品| 精品国产欧美| 日韩高清中文字幕一区二区| 国产精品99一区二区| 亚洲少妇一区| 天海翼精品一区二区三区| 日韩一区精品| 国产精品一区二区三区av| 美女视频黄免费的久久| 久久97视频| 日韩中文视频| 日韩一级精品| 免费久久99精品国产| 日本亚州欧洲精品不卡| 少妇精品久久久| 免费一级欧美片在线观看网站| 精品亚洲a∨| 国产在线|日韩| 日韩亚洲精品在线| 国产午夜一区| 美女av在线免费看| 欧美精品自拍| 国产调教精品| 日本高清不卡一区二区三区视频| 狠狠久久婷婷| 日日摸夜夜添夜夜添国产精品| 欧美激情网址| 亚洲福利久久| 日韩av资源网| 精品精品99| 免费精品国产的网站免费观看| 亚洲精品欧美| 精品99久久| 夜夜嗨一区二区| 国产精品中文字幕亚洲欧美 | 欧美亚洲人成在线| 久久毛片亚洲| 综合一区在线| 成人欧美一区二区三区的电影| 在线亚洲精品| 国产精品v日韩精品v欧美精品网站 | 国产精品黄色| 国产99精品| 日韩高清一区二区| 桃色一区二区| 97久久中文字幕| 欧美日韩视频免费观看| 亚洲毛片视频| 精品久久免费| 亚洲v天堂v手机在线| 成人国产精品| 综合激情网...| 精品国产a一区二区三区v免费| 六月婷婷一区| 国产成人久久精品一区二区三区| 喷白浆一区二区| 欧美欧美黄在线二区| 亚洲国内精品| 欧美国产精品| 羞羞答答国产精品www一本| 欧美xxxx性| 亚洲一区区二区| 日韩欧美网址| 91亚洲精品视频在线观看| 欧美男人天堂| 日本aⅴ精品一区二区三区| 99久久精品网| 日韩欧美中文字幕电影| 亚洲午夜天堂| 国产精品中文字幕亚洲欧美| 国内激情久久| 久久97久久97精品免视看秋霞| 亚洲精品精选| 久久精品国产亚洲夜色av网站| 国产精品日本一区二区三区在线| 一区二区自拍| 中文在线а√在线8| 日韩精品福利一区二区三区| 久久国产电影| 精品一区二区三区四区五区| 亚洲综合中文| 五月天久久777| 高清一区二区| 国产精品扒开腿做爽爽爽软件| 日韩天堂av| 秋霞国产精品| 日韩伦理福利| 久久伊人国产| 国产精区一区二区| 日韩一区二区三区精品 | 一区二区国产在线观看| 久久久久99| av综合电影网站| 91精品国产乱码久久久久久久| 91九色综合| 婷婷亚洲五月| 日韩精品不卡一区二区| 免费在线观看一区| 欧美亚洲色图校园春色| 亚洲日本免费电影| 亚洲在线观看| 精品中文字幕一区二区三区av| 亚洲女同av| 成人午夜网址| 成人午夜网址| 精品久久亚洲| 久久精品国产成人一区二区三区| 国产九九精品| 国产精品地址| 国产丝袜一区| 一本综合精品| 亚洲人成亚洲精品| 久久亚洲视频| 喷白浆一区二区| 蜜臀a∨国产成人精品| 免费久久久久久久久| 亚洲va在线| 99精品在线免费在线观看| 日韩久久精品| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 久久久精品五月天| 成人美女视频| 神马午夜在线视频| 超碰超碰人人人人精品| 久久国产电影| 国产精品videossex| 欧美一区在线观看视频| 日本va欧美va精品| 久久国产三级精品| 国产精品97| 久久av一区二区三区| 久久国产成人| 日本欧美一区二区| 日本精品另类| 国产精品大片免费观看| 国产欧美日韩| 久久亚洲黄色| 黄色在线观看www| 亚洲午夜视频| 天堂av在线一区| 午夜亚洲福利| 国产精品亚洲综合在线观看| 美女在线视频一区| 欧美aa一级| 国产精品美女久久久| 亚洲香蕉视频| 久久不见久久见中文字幕免费| 精品国产午夜| 国产精品97| 91亚洲精品在看在线观看高清| 国产欧美一区二区色老头| 六月丁香综合在线视频| 精品理论电影在线| 久久久久99| 亚洲精品三级| 国产精品毛片一区二区在线看| 久久亚洲专区| 日韩欧美中文在线观看| 欧美91在线|欧美| 99久久夜色精品国产亚洲1000部| 香蕉视频成人在线观看| 91亚洲无吗| 中文一区一区三区高中清不卡免费| 午夜欧美在线| 国产精品亚洲二区| 深夜福利视频一区二区| 人人精品人人爱| 精品网站aaa| 亚洲中字黄色| 精品国产三区在线| 免费日韩视频| 欧美激情视频一区二区三区免费| 天堂日韩电影| 国产无遮挡裸体免费久久| 久久久久中文| 日韩高清电影免费| www.com.cn成人| 亚洲精品三级| 日韩一区自拍| 日韩黄色免费网站| 日产午夜精品一线二线三线| 蜜桃一区二区三区在线| 精品91福利视频| 一区二区电影在线观看| 91亚洲人成网污www|