Vue 父组件与子组件之间的通信

1.我们知道组件其实是相当于一个vue实例,它有自己的data,method,template,components等等的数据,所以它想要拿到别人的数据是要通过一定的方式的,而不是随便就可以拿到别的组件的数据
2.官网查得
1)父组件通过props可向子组件传递数据
2)子组件通过事件向父组件传递数据
3.父传子props的使用

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div id="content">
    <!--使用子组件-->
    <childcom :message="message"></childcom>
</div>
<template id="temp">
    <div>
        <h2>{{message}}</h2>
    </div>
</template>
<script src="./vue.js"></script>
<script>
    //vue实例本身也是一个组件
    const app = new Vue({
        el: '#content',
        data: {
            message: '陈数'
        },
        //注册一个局部组件,即为子组件
        components: {
            'childcom': {
                template: "#temp",
                props: ['message']
            }
        }
    })
</script>
</body>
</html>

结果
在这里插入图片描述
props的分析
在这里插入图片描述
4.子传父事件使用
代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div id="content">
    <!--使用子组件-->
    <childcom @increment="changeMoney" @decrement="changeMoney"></childcom>
        <h2>money:{{money}}</h2>
</div>
<template id="temp">
    <div>
        <button @click="add"></button>
        <button @click="sub"></button>
    </div>
</template>
<script src="./vue.js"></script>
<script>
    //vue实例本身也是一个组件
    const app = new Vue({
        el: '#content',
        data: {
            message: '陈数',
            money: 0
        },
        methods: {
            //参数money用于接收子组件传来的数据
            changeMoney(counter) {
                this.money = counter
            }
        },
        //注册一个局部组件,即为子组件
        components: {
            'childcom': {
                template: "#temp",
                data() {
                    return {
                        counter: 0
                    }
                },
                methods: {
                    add() {
                        this.counter++
                        //发射事件给父组件,父组件通过@的方式将事件与它自己的方法绑定在一起然后处理数据,后面可以传参数
                        this.$emit("increment",this.counter)
                    },
                    sub() {
                        this.counter--
                        this.$emit("decrement",this.counter)
                    }
                }
            }
        }
    })
</script>
</body>
</html>

结果

在这里插入图片描述
分析
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值