zoukankan      html  css  js  c++  java
  • vue组件之间的通信

    1.子组件给父组件传递数据

    
    <body>
        <div id="app">
            父组件:{{total}}
            <br>
            <son-component v-bind:total="total"></son-component>
        </div>
        <script>
             Vue.component('son-component',{
                template:'<div>子组件:{{total}}+{{num}}={{add}}</div>',
                props:{
                    total:Number
                },
                data(){
                    return {
                        num:10
                    }
                },
                computed:{
                    add:function(){
                        return num=this.total+this.num
                    }
                }
            })
            var app=new Vue({
                el:'#app',
                data:{
                    total:1
                },
               
            })
        </script>
    </body>
    

    通过v-bind动态绑定父组件中要传递的数据,子组件通过props属性接收父组件传递的数据。

    2.父组件给子组件传递数据

    
    <body>
        <div id="app">
            <son-component v-on:change="getData"></son-component>
            <br>
            {{total}}
        </div>
        <script>
            Vue.component('son-component',{
                template:'<button v-on:click=sendData>点击我向父组件传值</button>',
                data(){
                    return{
                        count:1
                    }
                },
                methods:{
                    sendData:function(){
                        this.$emit('change',this.count)
                    }
                }
            })
            var app=new Vue({
                el:'#app',
                data:{
                    total:1
                },
                methods:{
                    getData:function(value){
                        this.total=this.total+value
                    }
                }
            })
        </script>
    </body>
    

    自定义一个事件,在子组件中通过this.$emit()触发自定义事件并给父组件传递数据,在父组件中监听自定义事件并接收数据。

    3.非父子组件之间的通信

    
    <body>
        <div id="app">
                <a-component></a-component>
                <b-component></b-component>
        </div>
        <script>
            Vue.component('a-component',{
                template:`
                    <div>
                        <span>a组件的数据:{{num}}</span><br>
                        <button v-on:click="sendData">击我向b组件传递数据</button>
                    </div>
                `,
                data(){
                    return {
                        num:1
                    }
                },
                methods:{
                    sendData:function(){
                        this.$root.bus.$emit('change',this.num)
                    }
                }
            })
            Vue.component('b-component',{
                template:`
                    <div>b组件接收a组件数据后相加的数据:{{count}}</div>
                `,
                data(){
                    return {
                        count: 10
                    }
                },
                created:function(){
                    this.$root.bus.$on('change',(value)=>{
                        //alert(value)
                        this.count=this.count+value
                    })
                }
            })
            var app=new Vue({
                el:'#app',
                data:{
                    bus:new Vue()
                },
            })
        </script>
    </body>
    

    原文地址:https://segmentfault.com/a/1190000016774374

  • 相关阅读:
    Mysql之数据库设计
    jQuery取得select选中的值
    抛java.lang.NoClassDefFoundError: org.joda.time.ReadablePeriod错误
    JS限制并且显示textarea字数
    myBaits association的使用
    IOS-Plist文件存储(1)
    Golang基于学习总结
    freemarker定义自己的标签错误(八)
    教你使用vim表白
    Cocos2d-x 3.2 大富翁游戏项目开发-第八部分 角色的散步路径
  • 原文地址:https://www.cnblogs.com/lalalagq/p/9901018.html
Copyright © 2011-2022 走看看