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

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Vue 2,你可以使用Vuex来管理应用程序的状态,包括获取数据。以下是一个简单的示例,演示如何在仓库获取数据: 1. 首先,确保已经安装了Vuex。可以使用npm或者yarn进行安装: ``` npm install vuex ``` 2. 在你的应用程序创建一个Vuex仓库。可以在`store.js`文件创建一个新的Vuex实例: ```javascript import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const store = new Vuex.Store({ state: { data: null }, mutations: { setData(state, payload) { state.data = payload } }, actions: { fetchData({ commit }) { // 在这里进行异步操作获取数据,例如使用axios发起请求 // 然后在获取数据后调用commit方法来更新仓库数据 const data = // 获取到的数据 commit('setData', data) } }, getters: { getData(state) { return state.data } } }) export default store ``` 在上面的代码,我们定义了一个名为`data`的状态,以及一个名为`setData`的mutation来更新该状态。我们还定义了一个名为`fetchData`的action,它可以用来异步获取数据并调用mutation来更新状态。最后,我们还定义了一个名为`getData`的getter来获取仓库数据。 3. 在你的Vue组件使用仓库数据。可以通过`mapGetters`来获取数据并在模板使用: ```vue <template> <div> <p>{{ data }}</p> <button @click="fetchData">获取数据</button> </div> </template> <script> import { mapGetters, mapActions } from 'vuex' export default { computed: { ...mapGetters(['getData']) }, methods: { ...mapActions(['fetchData']) } } </script> ``` 在上面的代码,我们使用`mapGetters`将`getData`映射到组件的计算属性,以便在模板使用。我们还使用`mapActions`将`fetchData`映射到组件的方法,以便在点击按钮时调用该方法。 现在,当你点击按钮时,它会触发`fetchData`方法,该方法会触发`fetchData` action,然后异步获取数据并将其存储在仓库的`data`状态。然后,你可以通过计算属性`getData`来获取仓库数据,并在模板使用它。 这就是在Vue 2使用Vuex获取数据的基本步骤。当然,你还可以根据实际需求进行更复杂的操作和配置。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值