子组件通过$emit触发父组件的事件,$emit后面的参数是向父组件传参,注意,父组件的事件处理函数直接写函数名即可,不要加(),参数直接传递到了父组件的methods的事件处理函数了。 另外,写一个小拾遗。vue子组件用了定义模板组件功能,然后在父组件里定义一个HTML元素绑定这个子组件后才能在父组件通过这个HTML元素使用。 再说一个非常方便的v-ref
Vue1.0组件间传递 使用$on()监听事件; Vue2.0后$dispatch(),$broadcast()被弃用,见https://cn./v2/guide/migration.html#dispatch-和-broadcast-替换
1,父组件向子组件传递场景:Father上一个输入框,根据输入传递到Child组件上。 父组件: <template> <div> <input type="text" v-model="msg"> <br> //将子控件属性inputValue与父组件msg属性绑定 <child :inputValue="msg"></child> </div> </template> <style> </style> <script> export default{ data(){ return { msg: '请输入' } }, components: { child: require('./Child.vue') } } </script 子组件: <template> <div> <p>{{inputValue}}</p> </div> </template> <style> </style> <script> export default{ props: { inputValue: String } } </script> 2,子组件向父组件传值场景:子组件上输入框,输入值改变后父组件监听到,弹出弹框
父组件: <template> <div> //message为子控件上绑定的通知;recieveMessage为父组件监听到后的方法 <child2 v-on:message="recieveMessage"></child2> </div> </template> <script> import {Toast} from 'mint-ui' export default{ components: { child2: require('./Child2.vue'), Toast }, methods: { recieveMessage: function (text) { Toast('监听到子组件变化'+text); } } } </script> 子组件:
vue2.0父子组件以及非父子组件如何通信1.父组件传递数据给子组件父组件数据如何传递给子组件呢?可以通过props属性来实现 父组件:
子组件通过props来接收数据:
方式2 :
方式3:
这样呢,就实现了父组件向子组件传递数据. 2.子组件与父组件通信那么,如果子组件想要改变数据呢?这在vue中是不允许的,因为vue只允许单向数据传递,这时候我们可以通过触发事件来通知父组件改变数据,从而达到改变子组件数据的目的.
父组件:
3.非父子组件通信
如果2个组件不是父子组件那么如何通信呢?这时可以通过eventHub来实现通信.
组件1触发:
组件2接收:
这样就实现了非父子组件之间的通信了.原理就是把Hub当作一个中转站!
|
|