VUE进阶 - $on和$emit的用法

2020-04-24  本文已影响0人  wyc0859

使用场景:兄弟组件之间相互传递数据

先上简单的用法,一个页面上使用

\color{red}{ uniapp中H5和小程序都支持 }

<template>
    <view class="content">
        <view>
            <view @click="sub">{{msg}}</view> 
        </view>
    </view>
</template>

<script>
    export default {
        data() {
            return {
                msg:"ok"
            }
        }, 
        onLoad(){
            this.$on("event_a",this.bind_a) //将函数绑定到事件
        },
        methods:{
            bind_a(e){
                this.msg= "绑定+"+e
            },
            sub(){
                this.$emit("event_a","传入的参数") //触发事件
            }
        }
    }
</script>

兄弟组件传值

//index.vue
<template>
    <view class="content">
        <view>
            <h3>组件A改动组件B</h3>
            <br/>
            <comp_a></comp_a>
            <br/>
            <comp_b></comp_b>
        </view>
    </view>
</template>

<script> 
    import comp_a from './a.vue'
    import comp_b from './b.vue'
    export default {
        data() {
            return { 
            }
        }, 
        onLoad(){ 
        },
        components:{
            comp_a,
            comp_b
        },
        methods:{
             
        }
    }
</script>
//a.vue
<template>
    <view>      
        <view  @click="sub">点我</view> 
    </view>
</template>

<script> 
    import eventBus from '@/common/eventBus.js'
    export default {
        data() {
            return { 
                data_a:"aaa"
            }
        }, 
        methods:{
            sub(){
                eventBus.$emit('eventa',this.data_a)
            }
        } 
    }
</script> 
//b.vue
<template>
    <view>
        {{msg}}
    </view>
</template>

<script>     
    import eventBus from '../../common/eventBus'
    export default {
        data() {
            return { 
                msg:"bbb"
            }
        },  
        mounted(){ 
            eventBus.$on('eventa',(val)=>{ 
                this.msg=val 
            })
        },
    }
</script> 
//eventBus.js
import Vue from 'vue'
export default new Vue() 
上一篇 下一篇

猜你喜欢

热点阅读