vue组件之间通讯总结---点赞

总结:
父组件--》子组件
①经过属性
步骤1:
<son myName="michael" myPhone='123'></son>
<son :myName="userList[0]"></son>
步骤2:
Vue.component('son',{
  props:['myName','myPhone']
})
②经过$parent
直接在子组件中经过this.$parent获得调用子组件的父组件html

子组件--》父组件
①events up
步骤1:在父组件中 调用子组件的时候 绑定一个自定义事件 和 对应的处理函数
methods:{
  recvMsg:function(msg){
  //msg就是传递来的数据
  }
},
template:'
<son @customEvent="recvMsg"></son>
'vue

步骤2:在子组件中 把要发送的数据经过触发自定义事件传递给父组件
this.$emit('customEvent',123)函数

②$refsthis

reference 引用
步骤1:在调用子组件的时候 能够指定ref属性
<son ref='zhangsan'></son>
步骤2:经过$refs获得指定引用名称对应的组件实例
this.$refs.zhangsanspa

兄弟组件通讯
步骤1:建立一个Vue的实例 做为事件绑定触发的公共的对象
var bus = new Vue();
步骤2:在接收方的组件 绑定 自定义的事件
bus.$on('customEvent',function(msg){
  //msg是经过事件传递来的数据 (传递来的123)
});
步骤3:在发送方的组件 触发 自定义的事件
bus.$emit('customEvent',123);code


每日一练:component

建立2个组件,main-component,son-componenthtm

视图:
main-component 显示一个按钮
son-component 显示一个p标签对象

功能:
main-component 定义一个变量count,初始化为0,将count传递给son-component,son-component接收到数据显示在p标签中blog

main-component 在点击按钮时,实现对count的自增操做,要求son-component可以实时显示count对应的数据

son-component在接收到count以后,在count大于10的时候,将main-component的按钮禁用掉
(参考:<button v-bind:disabled="!isValid">clickMe</button>)

<!doctype html>
<html>
 <head>
  <meta charset="UTF-8">
  <title>小练习</title>
    <script src="js/vue.js"></script>
 </head>
 <body>
  <div id="container">
        <p>{{msg}}</p>
        <main-component></main-component>
        
    </div>
    <script>
    /*
        每日一练:

建立2个组件,main-component,son-component

视图:
 main-component 显示一个按钮
 son-component 显示一个p标签

功能:
    main-component 定义一个变量count,初始化为0,将count传递给son-component,son-component接收到数据显示在p标签中

    main-component 在点击按钮时,实现对count的自增操做,要求son-component可以实时显示count对应的数据

    son-component在接收到count以后,在count大于10的时候,将main-component的按钮禁用掉
    (参考:<button v-bind:disabled="!isValid">clickMe</button>)
    */
//建立父组件
        Vue.component("main-component",{
            data:function(){
                return {
                    count:0,
                    isDisabled:true
                }
            },
            methods:{
                //点击按钮对count进行自增
                //并经过$emit触发countAdd,并把count的值传递给子组件
                //判断count==10的时候让按钮禁用
                countAdd:function(){
                    this.count++;
                    console.log("对数据进行自增:"+this.count);
                    this.$emit("countAdd",this.count);
                }
            },
            template:`
                <div>
                    <button @click="countAdd" v-bind:disabled="!isDisabled">点我</button>
                    <son-component v-bind:myCount="count"></son-component>
                </div>
            `
        })
//建立子组件
        Vue.component("son-component",{
            //经过props接收父组件传递过来的值
            props:["myCount"],
            template:`
                <div>
                    <p>{{myCount}}</p>
                </div>
            `,
            //数据更新完成后判断从父组件拿到的值
            updated:function(){
                if(this.myCount>10){
                    //子组件经过$parent直接获取父组件的数据
                        this.$parent.isDisabled = false;
                    }
            }
        })
        new Vue({
            el:"#container",
            data:{
                msg:"Hello VueJs"
            }
        })
    </script>
 </body>
</html>
相关文章
相关标签/搜索