vue中异步数据获取方式(确保数据被获取)

 更新时间:2022年01月24日 10:57:36   作者:二水你要努力啊  
这篇文章主要介绍了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处理数据(同步,异步)问题简单记录

情况介绍

在这里插入图片描述

后端返回该地址的坐标经纬度,需要前端用百度地图api处理成详情地址

处理过程在遍历中直接引入

在这里插入图片描述

处理完数据后返回并绑定到el-table列表

通过打印发现getLocation()方法响应过慢,导致数据渲染时该字段为空

最终解决方法:new Promise()

抽离出处理数据的方法,用异步处理方式返回

在这里插入图片描述

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

所以。。。。。在外层调用时同样需要异步操作

在这里插入图片描述

因为获取详情地址的方法是逐条处理的,所以在调用的外层进行了遍历

。。。。。。。。最终解决问题

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue的.vue文件是怎么run起来的(vue-loader)

    vue的.vue文件是怎么run起来的(vue-loader)

    通过vue-loader,解析.vue文件,在webpack解析,拆解vue组件 ,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友参考下
    2018-12-12
  • Vue3中的组合式 API示例详解

    Vue3中的组合式 API示例详解

    组合式 API 是一系列 API 的集合,使我们可以使用函数而不是声明选项的方式书写 Vue 组件,这篇文章主要介绍了什么是Vue3的组合式 API,需要的朋友可以参考下
    2022-06-06
  • element表单校验提示定位到元素位置

    element表单校验提示定位到元素位置

    本文主要介绍了element表单校验提示定位到元素位置,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • Vue.js中的computed功能设计

    Vue.js中的computed功能设计

    computed作为计算属性其作用是描述响应式数据的复杂逻辑计算,当所依赖的响应式数据发生改变时计算属性会重新计算,更新逻辑计算的结果,这篇文章主要介绍了Vue.js中的computed的功能设计,需要的朋友可以参考下
    2023-06-06
  • 使用vue ant design分页以及表格分页改为中文问题

    使用vue ant design分页以及表格分页改为中文问题

    这篇文章主要介绍了使用vue ant design分页以及表格分页改为中文问题,具有很好的参考价值,希望对大家有所帮助。
    2023-04-04
  • vue-父子组件和ref实例详解

    vue-父子组件和ref实例详解

    这篇文章通过实例代码给大家介绍了vue-父子组件传值和ref获取dom和组件的方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-11-11
  • vue自定义插件封装,实现简易的elementUi的Message和MessageBox的示例

    vue自定义插件封装,实现简易的elementUi的Message和MessageBox的示例

    这篇文章主要介绍了vue自定义插件封装,实现简易的elementUi的Message和MessageBox的示例,帮助大家更好的理解和使用vue框架,感兴趣的朋友可以了解下
    2020-11-11
  • vue-cli中的:visible.sync是什么意思

    vue-cli中的:visible.sync是什么意思

    visible前面加冒号的,说明后面是一个变量或者表达式;没加冒号的后面就是对应的字符串字面量,这篇文章主要介绍了vue-cli中的:visible.sync是什么,需要的朋友可以参考下
    2022-11-11
  • vue-resourc发起异步请求的方法

    vue-resourc发起异步请求的方法

    这篇文章主要介绍了vue-resourc发起异步请求的方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • vuex状态持久化在vue和nuxt.js中的区别说明

    vuex状态持久化在vue和nuxt.js中的区别说明

    这篇文章主要介绍了vuex状态持久化在vue和nuxt.js中的区别说明,具有很好的参考价值,希望大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04

最新评论