dva异步问题

发布于 2022-09-12 00:59:03 字数 702 浏览 27 评论 0

背景

有一个接口获取到用户列表,列表内有用户信息和id,但没有用户名,现有另一个接口根据用户id得到用户名,插入用户列表。

相关代码

// 请把代码文本粘贴到下方(请勿用图片代替代码)

  effects: {
     *fetch({ payload }, { call, put }) {
      const response = yield call(queryFakeList, payload);
      //存在异步问题 暂时无好的解决方法
      //fetchUserName是一个根据用户id获得用户名的方法,第二个参数是回调函数
      response.data.forEach(item => {
        fetchUserName(item.owner, data => {
          item.ownername = data[0].text;
        });
      });
      yield put({
        type: 'queryList',
        payload: Array.isArray(response.data) ? response.data : [],
      })
    },
  },

这里在执行过程中,存在异步问题

有没有办法在forEach的过程中回调函数已同步的方式执行,然后再执行yield put。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

悸初 2022-09-19 00:59:03

你的表述看懂了,写法没看懂。
我的理解,循环请求,拿到列表中所有的name。

      let userNames = []
      const {data=[]} = yield call(queryFakeList, payload)
      // 使用for循环
      for (let i = 0; i < data.length; i++) {
        const res = yield call(fetchUserName, data[i].id);
        userNames.push({id:res.id,name:res.name})
      }

注意:这样做不好,会发很多请求。
建议:和后端商议,让他们调整。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文