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

