Vue中的同步和异步调用顺序详解

 更新时间:2022年01月24日 11:55:55   作者:neoeson  
这篇文章主要介绍了Vue中的同步和异步调用顺序,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Vue的同步和异步调用顺序

Vue中的方法调用顺序是依次进行的,方法体内部也是依次执行的,但是,两个方法体的执行顺序并不能严格控制。

以下方法中都带有promise函数或异步调用。

    initUserData() {
      this.getPsCountryList() // 1 获取国家列表stateOptions,方法内同步
      this.getTimeZone() // 2 获取时区timezones,方法内同步
      this.getUserInfo() // 3 获取用户信息
    }

在实际运行中,三个方法的执行顺序是1-2-3,但是方法3始终不能获取到stateOptions和timezones

背后的调用顺序是1-2-3,但是,方法的执行时间并没有严格控制。

如果想要做到方法调用和执行是同步的,可以使用async和await修饰符。

例如

    async initUserData() {
      await this.getPsCountryList() // 1 获取国家列表stateOptions,方法内同步
      await this.getTimeZone() // 2 获取时区timezones,方法内同步
      await this.getUserInfo() // 3 获取用户信息
    }

Vue两个异步方法顺序执行

需求:两个异步函数按顺序执行,首先获取第一个异步函数的返回的值,接着在第二个异步函数里面调用

方法:先在第一个异步函数里返回一个promise,接着用async和await调用它

第一个异步方法

getAllNotice() {
                let data = {
                    "searchParams": [{
                        "fieldName": "equipmentId",
                        "operate": "eq",
                        "value": "000000"
                    }],
                    "size": -1
                }
                return new Promise((resolve) => {
                    API.getNotice(data).then(res => {
                        console.log(res)
                        if (res.data.code == "200") {
                            this.noticeList = res.data.data.list
                            console.log(this.noticeList)
                            resolve();
                            return
                        } else {
                            uni.showToast({
                                title: res.data.message,
                                duration: 1000,
                                icon: "none"
                            })
                        }
                    })
                })                
            },

第二个异步方法

//获得当前的公告列表
            getNowNotice(){
                //获取当前时间戳
                var timestamp = (new Date()).getTime();
                var _this = this
                console.log(timestamp);
                //将noticeList的结束时间转换成时间戳
                for(var i=0; i<this.noticeList.length; i++){
                    var endTimeStamp = TIME.TimeToTimeStamp(this.noticeList[i].endTime)
                    console.log(endTimeStamp)
                    if(endTimeStamp>timestamp){
                        _this.noticeNewList.push(this.noticeList[i])
                    }
                }
                console.log("noticeNewList",_this.noticeNewList)
            }

用async和await

async onLoad(option) {
            await this.getAllNotice()
            await this.getNowNotice()
        },

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

相关文章

  • 使用vue构建多页面应用的示例

    使用vue构建多页面应用的示例

    这篇文章主要介绍了使用vue构建多页面应用的示例,帮助大家更好的理解和使用vue,感兴趣的朋友可以了解下
    2020-10-10
  • vue3封装一个带动画的关闭按钮示例详解

    vue3封装一个带动画的关闭按钮示例详解

    这篇文章主要为大家介绍了vue3封装一个带动画的关闭按钮示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • Vue 3 表单与后端数据交互之查询并回显数据步骤流程

    Vue 3 表单与后端数据交互之查询并回显数据步骤流程

    本文给大家介绍Vue3表单与后端数据交互之查询并回显数据步骤流程,结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-12-12
  • vue 实现LED数字时钟效果(开箱即用)

    vue 实现LED数字时钟效果(开箱即用)

    这篇文章主要介绍了vue 实现LED数字时钟效果(开箱即用),每一个数字由七个元素构成,即每一个segment元素,本文给大家分享实现实例,感兴趣的朋友一起看看吧
    2019-12-12
  • vue elementui简易侧拉栏的使用小结

    vue elementui简易侧拉栏的使用小结

    这篇文章主要介绍了vue elementui简易侧拉栏的使用,增加了侧拉栏,目的是可以选择多条数据展示数据,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-06-06
  • 关于Vue脚手架中render 理解

    关于Vue脚手架中render 理解

    这篇文章主要介绍了Vue脚手架中的 render 理解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-10-10
  • vue仿ios列表左划删除

    vue仿ios列表左划删除

    这篇文章主要为大家详细介绍了vue仿ios列表左划删除,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-09-09
  • vue v-model表单控件绑定详解

    vue v-model表单控件绑定详解

    这篇文章主要为大家详细介绍了vue v-model表单控件绑定的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • vue+element-ui实现主题切换功能

    vue+element-ui实现主题切换功能

    这篇文章主要介绍了vue+element-ui实现主题切换功能,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • vue+el-menu实现菜单栏无限多层级分类

    vue+el-menu实现菜单栏无限多层级分类

    这篇文章主要为大家详细介绍了vue+el-menu实现菜单栏无限多层级分类,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03

最新评论