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