mingyunyuziyou

vue 的$emit看完这篇你就会用了

作者: 秒速五厘米     
 


在vue中我们常常会用到组件嵌套,对于新手来说,父子组件通信会经常困扰我们,不懂还在网站找例子?看完这篇你就会用了。

//父级
new Vue({
    el:"#app",
    data:{
        aaa:111,
        bbb:222
    },
    methods:{
        dosometing:function(msg){
            console.log(msg)
        }
    }
})
//组件:
Vue.component('child',{
        props:['aaa'],
        template:'<input type='text'>'
    });
//调用子组件
<child @change="dosometing" :aaa='111' :bbb='222'></child>

渲染出来的结果,没有被"props"接受的数据会直接绑到组件元素上

<input type="text" value="222">


但当在输入框输入的时候dosometing并未执行,说明绑定的change事件并没有绑上。如果用$emit

Vue.component('child',{
        props:['aaa'],
        template:"<input @click='childfun' type='text'>",
        methods:{
            childfun:function(){
                this.$emit('change');//触发事件
            }
        }
    });
//调用子组件
<child @change="doSomeTing" :aaa='111' :bbb='222'></child>

好搞定,当我们在childfun方法内输出this.change的时候,结果为undefined,说明change方法并没有挂载在组件实例下边。$emit相当于jq中的trigger事件,只不过是用子组件来触发父组件的方法。所以里面的this是父组件。

不过为了触发父级的事件我们并不是只有$emit可以实现


1.可以通过$parent来直接触发父级的事件

Vue.component('child',{
        props:['aaa'],
        template:"<input @click='childfun' type='text'>",
        methods:{
            childfun:function(){
               this.$parent.change1(1111)
    };//触发父级事件
            }
        }
    });

这种方法可以和$emit达到相同的效果
2.通过props以参数的形式把方法传过来


//父级
new Vue({
   el:"#app",
   data:{
       aaa:111,
       bbb:222
   },
   methods:{
       dosometing:function(msg){
           console.log(msg)
       }
   }
})
//组件:
Vue.component('child',{
       props:['aaa'],
       template:'<input type='text'>',
        childfun:function(){
               this.change1(1111)
   }
   });
//调用子组件
<child :change="dosometing" :aaa='111' :bbb='222'></child>

当然这样是执行了想要执行的方法,但是因为方法挂载到了子组件上所以方法内的this指向的是子组件,这时可以用vm = new Vue({}) 用vm来代替this,达到操控父组件数据的目的。