如果想在一个组件中调用另一个组件,在子组件中使用父组件数据和方法,在父组件中使用子组件数据,该如何做呢,现在我们就通过程序来学习父子组件之间的通讯
data:image/s3,"s3://crabby-images/71450/714501db8f6d6d361ef94e1f9ac9630c64010150" alt=""
https://cn.vuejs.org/v2/guide/components-props.html
0.bugs
1.data:image/s3,"s3://crabby-images/a5791/a57917ecd5e377179850f43164863dbfdf0fc92d" alt=""
模板要一个根元素.这是重要的
data:image/s3,"s3://crabby-images/baa7d/baa7d701b4c87ae59d6aa6c28c7ff091ecdd6b39" alt=""
这种alert的传参是错误的
data:image/s3,"s3://crabby-images/ab84f/ab84f770f69fb1d7774f4138e37f83b154db122f" alt=""
一.父子组件
1.vm相当于一个根组件,里面的components就相当于它的子组件
data:image/s3,"s3://crabby-images/2cabb/2cabb6bcacd031c6af1469789f0fdd84651c5257" alt=""
2.同理.我们可以在一个全局组件注册它的子组件
2.1创建组件
2.2注册组件
2.3使用组件
data:image/s3,"s3://crabby-images/381ae/381ae09385bac3708b06d57e6d654bca8f5088fc" alt=""
data:image/s3,"s3://crabby-images/17830/178300e52d78b68048c258d25c1e2399975ac8cf" alt=""
data:image/s3,"s3://crabby-images/145c2/145c22278d8c78de82c3aad8223328eb48a7f723" alt=""
二.子组件使用父组件数据
1.父组件在调用子组件的时候传递数据
:别名="父数据名称"
2.在子组件中注册父组件传递过来的数据
props:['别名1', ... ]
3.在子组件中使用父组件传递过来的数据
{{别名}}
data:image/s3,"s3://crabby-images/e4a6e/e4a6ef99bd447bcdc8d2e64e4a87855fe0f1bbdc" alt=""
这里看到子组件中没有数据
data:image/s3,"s3://crabby-images/37684/3768481c2613de82465a4f99369ae151544300f7" alt=""
我们从父组件传递数据
data:image/s3,"s3://crabby-images/9189c/9189c714d8ae7d09a9f62dcc325f7a3449bc196b" alt=""
我们在子组件中使用父组件传递过来的数据
三.子组件使用父组件方法
1.父组件传递方法名称给子组件(记住如果加圆括号就变成调用)
2.在子组件中定义方法,在方法中触发父组件传递过来的方法
this.$emit("父组件传递的方法名称")
3.在子组件中调用父组件传递的方发
@click="方法名称"
data:image/s3,"s3://crabby-images/585df/585dfee7526bdf0743fb0d00b7418e05d7991fd6" alt=""
data:image/s3,"s3://crabby-images/49001/490013d2d23e28f136e45731942c06640d098714" alt=""
data:image/s3,"s3://crabby-images/aa124/aa1249832c78293af5423b1af465b9a8de694b19" alt=""
四.父组件使用子组件数据
data:image/s3,"s3://crabby-images/a09f7/a09f7037eca8368b2fedbf797195607c2d84c820" alt=""
简单的说,就是父组件调用子组件,子组件从父组件获取的方法中,嵌入了自己的数据
1.定义父组件方法传递参数
2.将子组件的数据传递给从父组件获取的方法
this.$emit("父组件传递的方法","子组件传递的数据")
3.在父组件的方法中使用该数据
data:image/s3,"s3://crabby-images/10e7b/10e7b74b039c73db0ea78be2147e46137e2ed575" alt=""
data:image/s3,"s3://crabby-images/7673c/7673c6d039a20ad9597d4f5690f61c8bf26e1ed6" alt=""
网友评论