您好,登錄后才能下訂單哦!
今天給大家介紹一下vue中異步數據獲取方式是什么。文章的內容小編覺得不錯,現在給大家分享一下,覺得有需要的朋友可以了解一下,希望對大家有所幫助,下面跟著小編的思路一起來閱讀吧。
import { fetchList } from '@/api/article' //在created中即開始獲取 created() { this.getList() } methods:{ async getList() { this.listLoading = true //ES6寫法,與then方法鏈式調用相同,但比較簡潔直觀 //const的寫法,保證原數據不被更改 const { data } = await fetchList(this.listQuery) //被await阻塞的代碼 const items = data.items this.list = items.map(v => { }) this.listLoading = false }, }
eg1:
changeA(){ return 3 }, async getAsync(){ let a = 1 a = await this.changeA() console.log(a) //打印結果為3 }, //changeA中沒有異步操作,程序從上往下執行
eg2:
async changeA(){ let a =22 await setTimeout(()=>{ console.log('異步中') a = 33 }) console.log('異步結果') return a }, async getAsync(){ let a = 1 await this.changeA() console.log(a) }, //打印結果為 異步結果 22 //a的結果 異步中 //結論await并未阻塞異步的代碼
eg3:
changeA(){ return new Promise((resolve)=>{ setTimeout(()=>{ console.log('異步') resolve() },2000) }) }, async getAsync(){ await this.changeA() console.log('同步') }, //兩秒后打印結果 異步 同步 //結論:成功阻塞代碼
eg4:
changeA(){ return new Promise((resolve)=>{ setTimeout(()=>{ console.log('異步') resolve() },2000) }) }, async getAsync(){ this.changeA() console.log('同步') }, //先打印同步,兩秒后打印異步
總結:當await后面跟的函數存在異步且返回promise的時候,才會阻塞之后的同步代碼,由上述eg可以印證
tips:
async函數也會立即返回一個promise對象
返回promise函數,可以在該方法結束后,使用鏈式結構
methods:{ getProfile(id) { let query = { aid: id }; //返回一個promise對象 return new Promise(async resolve => { const {data} = await api.getProfileList(query) //被await阻塞的同步代碼 this.profileList = data; this.graphical(this.dataX, this.dataY); resolve(); }); }, //當得到賦值的時候,再打開彈窗 this.getProfile(aid).then(() => { this.dialogVisible3 = true; }); }
后端返回該地址的坐標經緯度,需要前端用百度地圖api處理成詳情地址
處理過程在遍歷中直接引入
處理完數據后返回并綁定到el-table列表
通過打印發現getLocation()方法響應過慢,導致數據渲染時該字段為空
抽離出處理數據的方法,用異步處理方式返回
返回的之中存在空值。。。
所以。。。。。在外層調用時同樣需要異步操作
因為獲取詳情地址的方法是逐條處理的,所以在調用的外層進行了遍歷
以上就是vue中異步數據獲取方式是什么的全部內容了,更多與vue中異步數據獲取方式是什么相關的內容可以搜索億速云之前的文章或者瀏覽下面的文章進行學習哈!相信小編會給大家增添更多知識,希望大家能夠支持一下億速云!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。