Vue 在子组件的 methods 中获取到 props 中的值以及 watch 监听不到 props 的问题

1.父子组件通信

父组件给子组件传参,最常见的方式:父组件中使用 v-bind 绑定传送,子组件使用 props 接收即可

<DistrictIdSelector
  :fieldType="2"
/>
props: {
  fieldType: {
    type: Number,
    default() {
      return 1;
    },
  },
},

这样的话,我们可以直接在模版中获取到fieldType的值了。
但是存在一个父子组件渲染异步的问题,通过这个方法传过来的值,在子组件 mounted 大概率获取不到,因为此时父组件的值还没有传过来。
如果你想要在子组件的 mounted 中获取传值的话最好做个延迟或者是监听。
为啥模版中可以使用 {{fieldType}} 没有问题呢?这就是 vue 的好处,因为这个值是响应式的,它是等到值有变化的时候就会自动更新的。

2.解决方案

watch监听的方式

watch: {
  fieldType: {
    immediate: true,  //很重要,初始化就可以被监听
    handler(newVal) {
      this.valueType = newVal;   //赋值给data
      this.getDistrictList();   //拿到参数后去做请求
    },
  },
},
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值