91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue中異步數據獲取方式是什么

發布時間:2022-01-24 13:33:22 來源:億速云 閱讀:189 作者:柒染 欄目:開發技術

今天給大家介紹一下vue中異步數據獲取方式是什么。文章的內容小編覺得不錯,現在給大家分享一下,覺得有需要的朋友可以了解一下,希望對大家有所幫助,下面跟著小編的思路一起來閱讀吧。

vue中異步數據獲取

1、獲取異步數據,通過async/await限制 

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對象

2、將一個方法的返回值

返回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;
        });
}

vue處理數據(同步,異步)問題簡單記錄

情況介紹

vue中異步數據獲取方式是什么

后端返回該地址的坐標經緯度,需要前端用百度地圖api處理成詳情地址

處理過程在遍歷中直接引入

vue中異步數據獲取方式是什么

處理完數據后返回并綁定到el-table列表

通過打印發現getLocation()方法響應過慢,導致數據渲染時該字段為空

最終解決方法:new Promise()

抽離出處理數據的方法,用異步處理方式返回

vue中異步數據獲取方式是什么

返回的之中存在空值。。。

所以。。。。。在外層調用時同樣需要異步操作

vue中異步數據獲取方式是什么

因為獲取詳情地址的方法是逐條處理的,所以在調用的外層進行了遍歷

以上就是vue中異步數據獲取方式是什么的全部內容了,更多與vue中異步數據獲取方式是什么相關的內容可以搜索億速云之前的文章或者瀏覽下面的文章進行學習哈!相信小編會給大家增添更多知識,希望大家能夠支持一下億速云!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

彰武县| 秭归县| 临沂市| 日照市| 桂阳县| 永善县| 盐池县| 乾安县| 梅河口市| 漳平市| 安西县| 荆门市| 石楼县| 永济市| 石屏县| 龙江县| 临潭县| 东丰县| 泾川县| 溧阳市| 高台县| 金乡县| 广水市| 安顺市| 阳泉市| 蚌埠市| 宁海县| 嘉祥县| 邹城市| 武冈市| 嫩江县| 崇义县| 马鞍山市| 闵行区| 车险| 台安县| 吴桥县| 台东市| 电白县| 盱眙县| 江津市|