vue子父组件传值,想要等axios返回之后再渲染子组件,但是不得行,怎么解决

发布于 2022-09-07 03:47:00 字数 594 浏览 11 评论 0

vue里面想通过prop传值给子组件,本身父组件绑定的值有默认值,希望能在axios后台返回数据之后,在本身的数据上extend 更多的对象再传到子组件,这个问题怎么解决呢?

<template>
  <a-component  :opt="opt" ></a-component>
</template>
<script>
  export default{
    data(){
      return {
        opt:{
          a:1,
          b:2
        }
      }
    },
    methods:{
        getList(){
            axios.get('').then(function (res) {
          _.extend(_this.opt,{
              c:3,d:4
          })
        })
        //打debugger看到是先进入子组件created方法接收为opt默认值,才到这里走接口扩展opt对象
        }
    }
  }
</script>

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

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

发布评论

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

评论(1

祁梦 2022-09-14 03:47:00

如果想让子组件在父组件有哪个数据的时候再渲染,可以在父组件上加一个判断条件,例如<a-component :opt="opt" v-if="opt.c == 3"></a-component>。但是即使是子组件先渲染出来了,但当axios请求结束后,即opt的数据改变后,也会自动传递给子组件,从而更改子组件的状态。所以感觉非要等到数据extend后再渲染子组件没有什么太大的必要。

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