zoukankan      html  css  js  c++  java
  • vue父子组件通信

    1.父组件传递数据给子组件
    
    
    父组件数据如何传递给子组件呢?可以通过props属性来实现
    父组件:
    <parent>
        <child :child-msg="msg"></child>  //这里必须要用 - 代替驼峰
    </parent>
    
    data(){
        return {
            msg: [1,2,3]
        };
    }
     

    子组件通过props来接收数据: 
    方式1:
    props: ['childMsg']
    
    方式2 :
    props: {
        childMsg: Array //这样可以指定传入的类型,如果类型不对,会警告
    }
    
    方式3:
    props: {
        childMsg: {
            type: Array,    //传入的类型
            default: [0,0,0] //这样可以指定默认的值
        }
    }
     
    2.子组件与父组件通信
    
    
    子组件:
    <template>
        <div @click="testClick"></div>
    </template>
    
    methods: {
        testClick() {
            this.$emit('test','123'); //$emit(even,value)even 是一个函数,value 是传给父组件的值      , 触发名为test方法, '123'为向父组件传递的数据
        }
    }
     
    
    
    父组件接收:  
    
    <div>
        <child @test="change" :msg="msg"></child>  //监听子组件触发的test事件,然后调用change方法
    </div>
    methods: {
        change(val) {
            this.msg = val;  // val: 123
        }
    }
     
    3.非父子组件通信
    如果2个组件不是父子组件那么如何通信呢?这时可以通过eventHub来实现通信. 
    所谓eventHub就是创建一个事件中心,相当于中转站,可以用它来传递事件和接收事件.
    
    let Hub = new Vue(); //创建事件中心
    
    
    组件1触发:
    <div @click="eve"></div>
    methods: {
        eve() {
            Hub.$emit('change','hehe'); //Hub触发事件
        }
    }
    
    组件2接收:
    <div></div>
    created() {
        Hub.$on('change', () => { //Hub接收事件
            this.msg = 'hehe';
        });
    }
     
    
    
    转载:https://www.cnblogs.com/hai-cheng/p/8021982.html
  • 相关阅读:
    eclipse远程调试Tomcat方法(转)
    Django表单字段汇总
    Django表单API详解
    django使用表单
    django自定义模板标签和过滤器
    django人类可读性
    django特殊的标签和过滤器
    Django内置模板标签
    Django模板语言详解
    django 动态生成PDF文件
  • 原文地址:https://www.cnblogs.com/zpw-1/p/10384793.html
Copyright © 2011-2022 走看看