24.Vue.js :子组件传值给父组件

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/vivian_1122/article/details/88773440

$emit()

子组件传值给父组件需要用到 $emit()方法
这个方法可以传递两个参数:一个事件名称,一个是需要传递的数据
<!DOCTYPE html>
<html lang="en">

<head>
    <title>子组件传值给父组件</title>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <script src="./vue.js"></script>
</head>

<body>
    <div id="app">
        <father></father>
    </div>
    <script>
        Vue.component('father', {
            template: '<div>我是父组件<p>我忘记了我的儿子叫{{mySonName}}</p><son @tellFatherMyname="getMySonName"></son></div>',
            data() {
                return {
                    mySonName: ''
                }
            },
            methods: {
                getMySonName(data) {
                    console.log(data)
                    this.mySonName = data
                }
            },
            components: {
                son: {
                    data() {
                        {
                            return {
                                myName: '小明'
                            }
                        }
                    },
                    template: '<button @click="emitMyName">我是儿子,我的名字叫{{myName}}</button>',
                    methods: {
                        emitMyName() {
                            //子组件传值给父组件需要用到$emit()方法,这个方法可以传递两个参数,一个是事件名称,
                            //一个是需要传递的数据
                            this.$emit('tellFatherMyname', this.myName)
                        }
                    },
                }
            }

        })

        var vm = new Vue({
            el: '#app',
            data: {

            }
        })
    </script>
</body>

</html>

猜你喜欢

转载自blog.csdn.net/vivian_1122/article/details/88773440