组件间的通信

本文详细介绍了Vue.js中父子组件间的五种通信方式:父向子传值、子向父传值、父组件调用子组件方法、子组件调用父组件方法以及子组件与子组件间传值。通过具体代码示例,帮助读者理解如何在不同场景下选择合适的通信策略。

1、父向子传值:

通过props传值

 <my-component :msg="msg"></my-component>

 //子组件
 Vue.component('my-component', {
    template: '#broTem',
    props: {
        'msg':String
    },
    created() {
        console.log(this.msg);
    }
});

2、子向父传值:

通过$emit传值

子组件

<template id="broTem">
    <div>
        <input type="button" value="我是子组件" @click="childMethods">
    </div>
</template>

Vue.component('my-component', {
    template: '#broTem',
    data() {
        return {
            msg: '子组件的数据'
        }
    },
    methods: {
        childMethods: function () {
            this.$emit('send-bro-msg', this.msg);
        },
    },
});

父组件

<div id="app">
    <my-component @send-bro-msg="sendBroMsg"></my-component>
</div>

new Vue({
    el: '#app',
    methods: {
        sendBroMsg: function (val) {
            console.log(val);
        }
    },
});

3、父组件调用子组件方法并传值(通过ref传值)

<div id="app">
    <input type="button" value="我是父组件" @click="parentMethods">
    <my-component ref="myCom"></my-component>
</div>


Vue.component('my-component', {
    template: '#broTem',
    methods: {
        childMethods: function (val) {
           console.log(val);
        }
    },
});

var vm = new Vue({
    el: '#app',
    data() {
        return {
            msg: '父组件的数据'
        }
    },
    methods: {
        parentMethods: function () {
            this.$refs.myCom.childMethods(this.msg);
        }
    },
});

4、子组件调用父组件方法并传值(通过$parent)

Vue.component('my-component', {
    template: '#broTem',
    data() {
        return {
            msg: '子组件的数据'
        }
    },
    methods: {
        childMethods: function () {
            this.$parent.parentMethods(this.msg);
        },
    },
});

var vm = new Vue({
    el: '#app',
    methods: {
        parentMethods: function (val) {
            console.log(val);//子组件的数据
        }
    },
});

5、子组件与子组件传值

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值