父组件向子组件传值
简短说来就是,父组件通过标签动态绑定来传递数据,子组件通过props,以数组的形势来接收。
首先写一个子组件header.vue。
html部分:
data:image/s3,"s3://crabby-images/baede/baedeb334bfdd646d5d2bb0fe50567038762c43d" alt=""
如果要从父组件接收数据,那么就要使用props。这个logo是在父组件中定义的。
js部分:
data:image/s3,"s3://crabby-images/d11ab/d11aba3ea2fbd36157d24afcee971e39a89c92c5" alt=""
父组件部分:在父组件中注册子组件。 logo就是子组件中接收的名字。后面是要传送的数据。
data:image/s3,"s3://crabby-images/ea11b/ea11b75a4fff324a7797f7a5682fa9b05dfd0523" alt=""
data:image/s3,"s3://crabby-images/efe85/efe85cdc576d4c6fb29ed5a19cd7f15382ca2384" alt=""
子组件向父组件传值
子组件主要通过事件传递数据给父组件。
子组件部分:要将input输入的用户名传到父组件中去。首先声明一个了方法 setUser,用 change 事件来调用 setUser。在setUser方法中通过this.$eimt来遍历 transferUser 事件,并返回 this.username。
其中 transferUser 是一个自定义的事件,功能类似于一个中转,this.username 将通过这个事件传递给父组件
data:image/s3,"s3://crabby-images/5adc3/5adc397f3819aa60289519ae894f51662555c27f" alt=""
data:image/s3,"s3://crabby-images/e5828/e582835895014cf92c50ed69b7521297b64608c6" alt=""
父组件部分
在父组件 App.vue 中,声明了一个方法 getUser,里面的msg就是子组件传送过来的username,用 transferUser 事件调用 getUser 方法,获取到从子组件传递过来的参数 username。
data:image/s3,"s3://crabby-images/24d42/24d4252b85d78a4ef7aa7253e496661279f5a05a" alt=""
data:image/s3,"s3://crabby-images/86d0d/86d0d7a74130cf7637927c156c3e07f604768016" alt=""
data:image/s3,"s3://crabby-images/1e7d1/1e7d1277f760548a8616bef6ab86d7d0ceb2204e" alt=""
网友评论