axios請求獲取到返回值
最近在學習Vue,碰到一個問題就是需要從后端獲取到某個返回值之后再運行后面的代碼。
一般調用axios接口都是這樣的格式。
this.$axios.post('api/xxxx/xxxxx', this.$qs.stringify({ username: 'qwerqw', password: '123456' })).then(res => { ... ... }).catch(error => { ... ... })
這樣的格式要想獲取到返回值的話,就要將代碼都寫在then
中,閱讀代碼的時候不是很清晰。于是網上各種搜,最后覺得這種方法能解決我的強迫癥。
login: async function() { let result = await new Promise((resolve,reject) => { this.$axios.post('api/xxxx/xxxxx', this.$qs.stringify({ username: 'qwerqw', password: '123456' })).then(res => { resolve(res.data) }).catch(error => { console.log(error) }) }) ... ... }
-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
按照這種方式去獲取到后端的返回值,就可以將剩下的邏輯放在axios請求外面了。
我的理解是,axios是一種異步請求方法,需要用await關鍵詞修飾,等到獲取到返回值后再執行后面的代碼。在使用await時,需要再function前添加async關鍵詞。
藍藍設計建立了UI設計分享群,每天會分享國內外的一些優秀設計,如果有興趣的話,可以進入一起成長學習,請掃碼藍小助,報下信息,藍小助會請您入群。歡迎您加入噢~~希望得到建議咨詢、商務合作,也請與我們聯系。
文章來源:csdn 作者:灰羊駝
分享此文一切功德,皆悉回向給文章原作者及眾讀者.
免責聲明:藍藍設計尊重原作者,文章的版權歸原作者。如涉及版權問題,請及時與我們取得聯系,我們立即更正或刪除。
藍藍設計( m.91whvog3.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 、平面設計服務