当父子组件需要用到对方的值的时候是不能访问对方data中的数据或methods的
那么当父向子传值的时候就在父组件中引入的子组件的标签上绑定属性
再把值传递过去
在子组件中要先把属性放入props数组中,才能使用

而子向父传值就要父组件提供方法给子组件,
(在父组件中找到子组件引入的标签,标签上@xxx=“父组件方法名”)
在子组件中调用父组件的方法并把值传给他
(子组件中直接调用this.$emit(“xxx”,参数) )
这样父组件就拿到子组件中的值了

但是有时会出现一些问题,就是传入的值是异步获取的,也就是说,页面渲染到子组件时
数据还没回来,于是子组件就获得了一个空值,
这时可以使用watch来监视props中的数据

//xxx就是父组件通过异步请求获取到的值
props:['xxx']
watch:{
	xxx:function(){
		
	}
}
//始终监视值得变化一旦有值传来了就会调用执行方法
Logo

前往低代码交流专区

更多推荐