20 Vue父子组件传值

父子组件传值

A 父组件向子组件传值

父组件可以在引用子组件的时候,通过属性绑定的形式,把数据传递给子组件

父组件可以在引用子组件的时候,通过事件绑定的形式,把方法传递给子组件

下面是一个例子:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>父子组件</title>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>

</head>

<body>
    <div id="app">
        <!--父组件可以在引用子组件的时候,通过属性绑定的形式,把数据传递给子组件-->
        <!--父组件可以在引用子组件的时候,通过事件绑定的形式,把方法传递给子组件-->
        <comp v-bind:parentmsg="msg" v-on:func="show"></comp>
    </div>
    <template id="templ">
        <div>
            <h3>子组件--{{parentmsg}}</h3>
            <input type="button" value="触发父组件方法" @click="myclick">
        </div>
    </template>

    <script>
        var vm = new Vue({
            el: "#app",
            data: {
                msg: "hello"
            },
            methods: {
                show() {
                    console.log("父show方法")
                }
            },
            components: {
                comp: {
                    template: "#templ",
                    // 用于接收父组件传回的值
                    props: ['parentmsg'],
                    methods: {
                        myclick() {
                            // 调用父组件传回的func方法
                            this.$emit("func")
                        }
                    },
                }
            }
        })
    </script>
</body>

</html>

请牢记:绑定的值需要使用props数组进行接收,且不能有大写。props数组中的数据最好不要更改,如果涉及到需要改变的数据,最好使用data对象。

B 子组件向父组件传值

子组件向父组件传值其实是通过绑定父组件的方法实现的,以下为一个例子:

<body>
    <div id="app">
        <!--父组件可以在引用子组件的时候,通过事件绑定的形式,把方法传递给子组件-->
        <comp v-on:func="show"></comp>
    </div>
    <template id="templ">
        <div>
            <input type="button" value="触发父组件方法" @click="myclick">
        </div>
    </template>

    <script>
        var vm = new Vue({
            el: "#app",
            data: {
                msg: "hello"
            },
            methods: {
                show(data) {
                    console.log("父show方法获取子组件的值:" + data)
                }
            },
            components: {
                comp: {
                    template: "#templ",
                    methods: {
                        myclick() {
                            // 调用父组件传回的func方法
                            this.$emit("func", 123)
                        }
                    },
                }
            }
        })
    </script>
</body>

这样父组件则可以获取子组件的数据123

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值