vue中⽗⼦组件传值问题(深度监听)
vue中⽗⼦组件传值问题
普通的⽗⼦组件通常都是在⼦组件中绑定某个属性,在⼦组件中⽤props接收,⼦组件通过$emit将值传递给⽗组件。⽗组件通过$emit传递的函数和值来得到⼦组件的值。
// ⽗组件中,⼦组件的写法
// id 是要传递到⼦组件的值
<subCompont @hideHandle="drawerHide" :id="id"></subCompont>
// ⼦组件接收从⽗组件传来的值
props:{// 或者简单写法 props:["id"]
id:{
type:[Number,String],海口翻译
default:0
}
}
// ⼦组件中向⽗组件提交值
this.$emit('hideHandle',fal)
//watch监听值是否接收到传来的值,当接收到时执⾏某函数
watch:{
id(val){
<(val)// 当监听到传来的值得时候执⾏此函数
}
convenient
}
krater// ⽗组件接收从⼦组件传来的值
/
/ 上⾯的hiedHandle看到没有,$emit就是向这个绑定的属性传值的,drawerHide会接收传来的值
drawerHide(val){
// val表⽰传来的值
console.log(val)
英语ppt下载}
通常我们⽗⼦组件传值并不只是需要这个值,⽽是需要这个值得同时进⾏⼀些操作。我们⼀般通过watch监听传来的值,如果值传来了,将执⾏watch中的操作。
watch:{
'id':(val)=>{
<(val)
}
颜色的英文}
watch:{
id:(val)=>{
<(val)
}
vit}
watch:{
id(val){
<(val)
}
}
但是我就⽐较倒霉了,我遇到了监听不到的情况,因此遇到的深度监听
watch:{
id:{
deep:true,// 深度监听
handler(val){// 监听到后执⾏handler⽅法
<(val)
}
时态}
}
这样确实解决了⼀部分问题,但是更倒霉的是我还遇到了,第⼀次监听不到的情况
watch:{
id:{
kill是什么意思deep:true,// 深度监听
immediate:true,// 监听到后,⽴即执⾏ handler⽅法高压油泵
handler(val){
<(val)
}
}golove
}
这样就基本覆盖了所有⽗⼦组件传值的时候watch监听不到的情况了