码迷,mamicode.com
首页 > 其他好文 > 详细

单向数据流

时间:2018-10-17 00:12:18      阅读:142      评论:0      收藏:0      [点我收藏+]

标签:img   meta   cli   传递   ack   hang   更新   变化   new   

在上一篇的父子组件中,我们知道,当我们使用动态props将父组件的数据传递到子组件的时候,如果父组件的数据变化,子组件的数据会随之变化。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>vue</title>
    <script src="bower_components/vue/dist/vue.js"></script>
</head>
<body>
    <div id="box">
        <aaa></aaa>
    </div>

    <template id="aaa">
        <p @click="changeText">我是父组件</p>
        <bbb  :c-mess="pmsg"></bbb>
    </template>
    <script>
        var vm=new Vue({
            el:#box,
            data:{
                a:aaa
            },
            components:{
                aaa:{
                    data(){
                        return {
                           pmsg:动态props,
                        }
                    },
                    template:#aaa,
                    methods:{
                        changeText(){
                            this.pmsg = 数据流
                        }
                    },
                    components:{
                        bbb:{
                             props:[c-mess],
                            template: `
                                <div>
                                    <div>我是子组件 --- {{cMess}}</div>
                                <div>
                            `,
                        }
                    }
                }
            }
        });
    </script>
</body>
</html>

技术分享图片  技术分享图片

父组件数据变化时,子组件数据会相应变化;而子组件数据变化时,父组件数据不变

我们知道,子组件的值是通过emit主动发送到父组件的,需要事件驱动,如果子组件的数据发生改变时,没有事件驱动,父组件的数据并不能随之更新。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>vue</title>
    <script src="bower_components/vue/dist/vue.js"></script>
</head>
<body>
    <div id="box">
        <aaa></aaa>
    </div>

    <template id="aaa">
        <div>
            <span>父组件数据</span>
            <input v-model="msg">
        </div>
        <p>{{msg}}</p>
        <bbb :child-msg="msg"></bbb>
    </template>
    <script>
        var vm=new Vue({
            el:#box,
            components:{
                aaa:{
                     data(){
                        return {
                        msg:match
                        }
                    },
                    template:#aaa,
                    components:{
                        bbb:{
                            props:[childMsg],
                            template: `
                                 <div>
                                    <span>子组件数据</span>
                                    <input v-model="childMsg">
                                </div>
                                <p>{{childMsg}}</p>
                            `,
                        }
                    }
                }
            }
        });
    </script>
</body>
</html>

技术分享图片     技术分享图片

单向数据流

标签:img   meta   cli   传递   ack   hang   更新   变化   new   

原文地址:https://www.cnblogs.com/yuyujuan/p/9800979.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!