vue實(shí)現(xiàn)在一個(gè)方法執(zhí)行完后執(zhí)行另一個(gè)方法的示例
用Promise來(lái)實(shí)現(xiàn)
function2(){
// 你的邏輯代碼
return Promise.resolve(/* 這里是需要返回的數(shù)據(jù)*/)
}
function3(){
// 你的邏輯代碼
return Promise.resolve(/* 這里是需要返回的數(shù)據(jù)*/)
}
// 調(diào)用
function1(){
this.function2().then(val => {
this.function3();
});
}
拓展知識(shí):vue解決一個(gè)方法同時(shí)發(fā)送多個(gè)請(qǐng)求的問(wèn)題
在項(xiàng)目開(kāi)發(fā)過(guò)程中,讓人抓狂之一的問(wèn)題就是一個(gè)點(diǎn)擊事件,當(dāng)快速點(diǎn)擊的時(shí)候,它會(huì)重復(fù)發(fā)送多個(gè)請(qǐng)求。這是不允許出現(xiàn)的。
但是怎么解決這個(gè)問(wèn)題呢?
一般處理方法,就是點(diǎn)擊的時(shí)候,立刻將該按鈕disabled,這樣就可以避免重復(fù)發(fā)送請(qǐng)求了。但是我發(fā)現(xiàn)這個(gè)有一個(gè)弊端,那就是:
如果,該事件有許多的驗(yàn)證,比如電話(huà)、郵箱格式是否正確呀,必填的是否填了呀等等。一旦你點(diǎn)擊就把按鈕disabled了,發(fā)現(xiàn)該填的沒(méi)填,回去填完后發(fā)現(xiàn)按鈕不能點(diǎn)了?那是因?yàn)閯偛劈c(diǎn)擊的時(shí)候被你disabled了,所以還得在驗(yàn)證的方法中取消按鈕的disable。就造成了你點(diǎn)擊的時(shí)候,第一步,將按鈕disable了,然后一步一步向下驗(yàn)證,如果驗(yàn)證出錯(cuò),得取消disable,當(dāng)所有驗(yàn)證通過(guò)了,在請(qǐng)求的回調(diào)函數(shù)中,成功了也要取消disable,失敗了也要取消disable,因?yàn)槭×擞脩?hù)多半還會(huì)繼續(xù)點(diǎn)兩次,不取消disable會(huì)讓用戶(hù)發(fā)現(xiàn)怎么點(diǎn)不了了。這就造成了全篇都是按鈕disable的設(shè)置與取消。一旦有修改,很難維護(hù)的。
在vue中,有一個(gè)lodash,我們只需引入就可以使用了。
比如以下代碼:
<template>
<div>
<div class="bindBtn">
<button class="bindDataBtn" @click="postAction">提交</button>
</div>
</div>
</template>
<script>
import _ from 'lodash'
export default {
data() {
return {
}
},
mounted() {
},
methods: {
sendAjax(){
/*這里是請(qǐng)求的接口、參數(shù)以及回調(diào)函數(shù)等*/
},
postAction(){
this.doPostAction()
}
},
created(){
this.doPostAction = _.debounce(this.sendAjax,500);
}
}
</script>
我們首先將發(fā)送請(qǐng)求的ajax方法寫(xiě)在一個(gè)函數(shù)里面,在這里就是sendAjax函數(shù),其次,我們引入lodash,然后將sendAjax這個(gè)函數(shù)用一個(gè)方法自定義一下,在這里就是doPostAction,其中_是我們引入的lodash,_.debounce是一個(gè)限制操作頻率的函數(shù),里面的是500是毫秒單位。
當(dāng)執(zhí)行點(diǎn)擊事件的時(shí)候,也就是postAction函數(shù),我們只需要調(diào)用doPostAction這個(gè)函數(shù)就可以了,而那個(gè)500的功能就是你在這個(gè)時(shí)間段里,無(wú)論執(zhí)行了多少次這個(gè)點(diǎn)擊事件,它都只會(huì)執(zhí)行一次。
這樣就少了我們通篇disable來(lái)disable去
最后附上官網(wǎng)例子:點(diǎn)擊前往
以上這篇vue實(shí)現(xiàn)在一個(gè)方法執(zhí)行完后執(zhí)行另一個(gè)方法的示例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue-router路由傳參及隱藏參數(shù)問(wèn)題
這篇文章主要介紹了vue-router路由傳參及隱藏參數(shù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12
vue代理如何配置重寫(xiě)方法(pathRewrite與rewrite)
這篇文章主要介紹了vue代理如何配置重寫(xiě)方法(pathRewrite與rewrite),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
vue引入elementUi后打開(kāi)頁(yè)面報(bào)錯(cuò)Uncaught?TypeError的解決方式
這篇文章主要給大家介紹了關(guān)于vue引入elementUi后打開(kāi)頁(yè)面報(bào)錯(cuò)Uncaught?TypeError:?Cannot?read?properties?of?undefined(reading?‘prototype‘)的解決方式,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
vue項(xiàng)目如何引入element?ui、iview和echarts
這篇文章主要介紹了vue項(xiàng)目如何引入element?ui、iview和echarts,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
Vue3+Element?Plus使用svg加載iconfont的處理方法
這篇文章主要介紹了Vue3+Element?Plus使用svg加載iconfont的解決方案,本文詳細(xì)介紹了如何在Element?Plus中使用iconfont,簡(jiǎn)單的說(shuō)就是要將其封裝成SVG,并且支持動(dòng)態(tài)修改顏色,需要的朋友可以參考下2022-08-08

