Vue 防止短時(shí)間內(nèi)連續(xù)點(diǎn)擊后多次觸發(fā)請(qǐng)求的操作
如果連續(xù)點(diǎn)擊提交按鈕,可能會(huì)重復(fù)提交數(shù)據(jù),導(dǎo)致出錯(cuò),解決的方法可以使用disabled限制點(diǎn)擊,感覺(jué)體驗(yàn)不是太好,所有給大家分享下面的方法
<el-button @click="throttle()">測(cè)試</el-button> export default { data(){ return { lastTime:0 //默認(rèn)上一次點(diǎn)擊時(shí)間為0 } } }
methods:{ throttle(){ //獲取當(dāng)前時(shí)間的時(shí)間戳 let now = new Date().valueOf(); //第一次點(diǎn)擊 if(this.lastTime == 0){ console.log('觸發(fā)事件'); this.lastTime = now; }else{ if((now-this.lastTime) > 2000){ //重置上一次點(diǎn)擊時(shí)間,2000是我自己設(shè)置的2秒間隔,根據(jù)自己的需要更改 this.lastTime = now; console.log('間隔大于2秒,觸發(fā)方法'); //添加自己要調(diào)用的方法 }else{ console.log('不觸發(fā)'); } } }, }
這種方法雖然很好,但是遇到請(qǐng)求超時(shí)的情況可能不是太好處理(網(wǎng)絡(luò)原因、數(shù)據(jù)太大)。考慮通過(guò)后端是否返回res來(lái)控制。方法還有待提高!僅供參考~
補(bǔ)充知識(shí):解決vuex中module過(guò)多時(shí),需一個(gè)個(gè)引入的問(wèn)題
在項(xiàng)目開發(fā)中,使用vuex,如果項(xiàng)目過(guò)大,vuex就需要模塊化,但是如果module分的過(guò)多,我們就需要在store的index.js中一個(gè)個(gè)引入,這樣未免太麻煩,所以webpack出來(lái)了個(gè)配置,可以解決這個(gè)問(wèn)題,無(wú)需多次引入,懶癌患者福音,
以下是解決方案
import Vue from 'vue' import Vuex from 'vuex' import getters from './getters' Vue.use(Vuex) const modulesFiles = require.context('./modules', true, /\.js$/) const modules = modulesFiles.keys().reduce((modules, modulePath) => { const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1') const value = modulesFiles(modulePath) modules[moduleName] = value.default return modules }, {}) const store = new Vuex.Store({ modules, getters }) export default store
配置了這個(gè)后就無(wú)需一個(gè)個(gè)引入模塊了;
以上這篇Vue 防止短時(shí)間內(nèi)連續(xù)點(diǎn)擊后多次觸發(fā)請(qǐng)求的操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue中使用gantt-elastic實(shí)現(xiàn)可拖拽甘特圖的示例代碼
這篇文章主要介紹了vue中使用gantt-elastic實(shí)現(xiàn)可拖拽甘特圖,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07Vue?ElementUI在el-table中使用el-popover問(wèn)題
這篇文章主要介紹了Vue?ElementUI在el-table中使用el-popover問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04使用watch監(jiān)聽路由變化和watch監(jiān)聽對(duì)象的實(shí)例
下面小編就為大家分享一篇使用watch監(jiān)聽路由變化和watch監(jiān)聽對(duì)象的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02vue使用element-ui tabs切換echarts解決寬度100%方式
這篇文章主要介紹了vue使用element-ui tabs切換echarts解決寬度100%方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07Element?UI/Plus中全局修改el-table默認(rèn)樣式的解決方案
element ui官方封裝好的el-table組件,好用是挺好用的,但不可避免的是默認(rèn)的樣式,下面這篇文章主要給大家介紹了關(guān)于Element?UI/Plus中全局修改el-table默認(rèn)樣式的解決方案,需要的朋友可以參考下2023-02-02vue實(shí)現(xiàn)手機(jī)號(hào)碼的校驗(yàn)實(shí)例代碼(防抖函數(shù)的應(yīng)用場(chǎng)景)
這篇文章主要給大家介紹了關(guān)于vue實(shí)現(xiàn)手機(jī)號(hào)碼的校驗(yàn)的相關(guān)資料,主要是防抖函數(shù)的應(yīng)用場(chǎng)景,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09antd-DatePicker組件獲取時(shí)間值,及相關(guān)設(shè)置方式
這篇文章主要介紹了antd-DatePicker組件獲取時(shí)間值,及相關(guān)設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10