Bootstrap

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();   //拿到参数后去做请求
    },
  },
},
;