vue 组件间数据撞车了怎么办?就是提供数据的源组件还没得到数据,但是其他组件就已经需要源组件提供数据进行渲染了?

发布于 2022-09-11 23:44:52 字数 1544 浏览 24 评论 0

问题描述

Snipaste_2019-11-26_14-47-33.png

Snipaste_2019-11-26_15-02-59.png

问题出现的环境背景及自己尝试过哪些方法

我用的是setTimeOut方法,让他晚点再执行生命周期钩子函数,但是不知道这样是不是符合开发要求,有没有什么不可忽略的弊端

相关代码

//userInfoComp
created() {
      var self = this
      function getUserInfo(){
        return self.axios({//获取用户信息
            method: "post",
            url: "/userInfo",
            params: {
              userId: "1601"//得改
            }
          })
      }
      self.axios.all([getUserInfo()])
        .then(self.axios.spread(function(acct){
          //把所有数据都存在vuex中的userInfoData中了
          self.initUserInfo(acct.data);
        }))
        .catch(err=>{
          console.log(err)
        })
    },
//myTeamComp
mounted() {
      var self = this;
      setTimeout(function () {
        self.axios({
          url: '/team',
          params: {
            leader: self.userInfoData.teamleader
          }
        })
          .then((res) => {
          //把返回的所有队伍信息存起来用来渲染显示.
            self.myTeamMember = res.data
          })
          .catch(error => {
            self.$message({
              message:"信息加载失败,请稍后再试",
              type:"error",
              duration:1500,
              showClose:true
            })
          })
      }, 100)
    }

你期待的结果是什么?实际看到的错误信息又是什么?

想问问这个方法可行吗?有没有更通用的方法
谢谢

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

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

发布评论

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

评论(2

万人眼中万个我 2022-09-18 23:44:52

使用v-if来控制组件的渲染,当userInfoComp数据接口成功拿到之后再把myTeamComp置为true

优雅的叶子 2022-09-18 23:44:52

按照你的逻辑只能是数据没有取到的时候不要去渲染该组件,
或者初始化一些模拟数据

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