vue 组件参数得传递与父组件接口慢 导致子组件数据不能成功渲染

实际开发中,为了减少代码量,通常会写组件来进行复用,这就牵扯到了组件间得参数传递,假如我们写的组件中 需要调用接口 来渲染组件得数据,而调用组件中接口得入参又需要从父组件中调用接口来获得的,那么这就会发生问题,如果两个接口的速度一样快还好 ,可是一旦子组件中接口的速度快,而父组件中的接口的速度慢的话,就会发生组件中想要调用接口的入参是 空 没有 ,这样接口调用不成功,子组件中的数据就渲染不出来,那么怎么解决这个问题那?

首先我们假设 需要用父组件中的接口返回的code 传递给子组件 ,子组件中用code调用接口,来查询学生信息

这里我们用setTimeout 模拟接口

父组件

<template>
  <div id="app">
   <alert :code='code' ref="alert"></alert>
  </div>
</template>
<script>
import alert from '@/components/alert.vue'
export default {
  components:{alert},
  data() {
    return {
      code:''
    }
  },
  created() {
    this.getData()
  },
  methods: {
    getData(){
      setTimeout(() => {
       this.code = 123
      }, 1000);
    },
  }
}

子组件

<template>
  <div>
    <div>
      学生姓名:{{user.name}}
    </div>
    <div>
      学生年龄:{{user.age}}
    </div>
  </div>
</template>

<script>
export default {
  props: ['code'],
  data() {
    return {
      user: {}
    }
  },
  created() {
 console.log(this.code);
    setTimeout(() => {
      if (this.code == 123) {
        this.user = {
          name: '小明',
          age: 18
        }
      }
    }, 500);
  },
  watch: {
    code(val, old) {
    //     console.log(val);
    //   setTimeout(() => {
    //     if (val == 123) {
    //       this.user = {
    //         name: '小明',
    //         age: 18
    //       }
    //     }
    //   }, 500);
    }
  }
}

上面的代码一运行之后 效果是这样的 

 我们看控制台 获取不到code 是因为 父组件中接口慢 导致 传递过来的code 是空

我们可以用监听watch 监听code 在监听里面调用接口 这样就保证 父组件传过来的code 一定能接收到 无论接口的快慢

 

 

我们看 这样 数据成功被渲染了出来 控制台上 code 也被打印了出来

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 3 中,组件传递组件参数发生改变时,组件应该及时更新。如果组件没有及时更新,可能是由于以下几个原因: 1. 使用了不可变对象:Vue 3 在进行响应式更新时,会对比新旧是否相等。如果你使用了不可变对象(如使用 `Object.freeze` 冻结了对象),Vue 3 将无法检测到对象的变化,导致组件不更新。确保传递参数是可变的对象。 2. 使用了 `v-if` 条件渲染:如果你使用了 `v-if` 条件渲染来控制组件的显示和隐藏,当组件传递参数发生改变时,组件可能无法及时更新。这是因为 Vue 3 在条件渲染时会缓存之前的组件实例,而不是销毁和重新创建。你可以尝试使用 `v-show` 或者给组件添加一个唯一的 `key` 来解决这个问题。 3. 直接修改了数组或对象的元素:Vue 3 在进行响应式更新时,只会对已经被访问过的属性进行追踪。如果你直接修改了数组或对象的元素,而不是通过 Vue 提供的方法(如 `push`、`pop`、`splice` 等)进行修改,Vue 3 将无法检测到这些变化,导致组件不更新。请确保使用 Vue 提供的方法来修改数组或对象。 如果以上的解决方案都没有解决你的问题,你可以检查一下是否有其他因素导致组件不更新,比如在组件中是否正确地传递参数,或者组件是否正确地接收了参数。你也可以提供一些代码片段,以便更好地帮助你解决问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值