Vue组件以及vue传参方式

Vue组件

1、组件是什么?
  1. 是vue.js最强大的功能之一
  2. 可以扩展html元素,封装可重用的代码
2、注册全局组件
Vue.component('组件名称',引入的.vue文件)

main.js
import heads from 'src/heads';
Vue.component('heads',heads)
// 然后在页面直接引用heads标签就可以了

3、prop
  • 是父组件用来传递数据的一个自定义属性
  • 父组件的数据需要通过props把数据传给子组件,子组件需要显示地用props选项声明’prop’’
参数:
    props:{
        Child:{
            type:Number,
            required:true  // 默认值是false
            default:{
                return{
                    msg:'hello!'
                }
            }
        }
    }
4、自定义事件
  • $on(even) 监听事件
  • $emit(even) 触发事件
5、组件通讯
1、同级目录
    全局: window.Eventhub = new Vue();
    发送:methods:{
            send(){
                 EventHub.$emit('HowAre',this.val)
            }
        }
    接收:mounted(){
            EventHub.$on('HowAre',res=>{
                this.val = res
            })
        }
2、父级向子级通讯(利用props)
    父级:
        data(){
            return{
                tit:'加油加油 !'
            }
        }
    子级:
        props:['tit'] 接收
        <val1 :tit="tit"></val1>
3、子级向父级通讯(利用回调函数)
    子级:
        this.$emit('solgan',this.val)
    父级:
        <val1 @solgan='onSolgan'></val1>
         methods:{
            onSolgan(val){
                this.solgan = val
            }
        }
4、组件components/component
  1. 局部(components)
多个
components:{
    组件名称:{
        name:
        data(){
        },
        methods:{
        },
        beforeCreate:{
        }
        template = html字符串
        // template有且只有一个子元素
           }
}
  1. 全局(component)
Vue.component('组件名称',引入的.vue文件)
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值