vue中的组件是自定的标签,能够扩展的原生html元素,封装可复用的代码
note:
一、在标签命中不要使用大写,标签名字必须用短横线隔开
二、模板中只能有一个根元素,不能使用并列标签。html
- 全局定义,在全部实例中均可以使用这个组件
<template id='hello'> <div> <div>hello</div> <div>world</div> </div> </template> let data={msg:'world'} Vue.component('myComponent',{ template:'#hello',//经过模板的ID来引用这个组件 return {msg:'world'};//此时不能return data;这样会致使若是有多个实例运用这个组件会致使,三者共享同一个data,改变其中一个,会致使其余的都改变。对象变量会致使共享数据。 }) 此时就能够在实例中使用my-component标签。
- 局部定义
let vm=new Vue({ el:'#app', data:{msg:'hello'}, components:{ 'my-component'(myComponent):{ template:'<h1>{{msg}}</h1>', data(){ return {msg:'world'}; } } } }) 一、子组件不能直接使用父组件的数据 二、子组件能够声明本身的数据
一、每一个组件是不要紧的,都应该产生本身的数据。在组件中data使用的方法和默认的vm同样。只是data再也不是对象而是函数。组件能够无限嵌套。 二、声明组件的名字,不能为已经存在的标签 三、组件的嵌套,子组件必须写在父组建的模板中才能使用
- 一、父级向子级传递数据(传递的属性值)
一、若是直接写a='b'格式传递的是字符串,动态数据获取用的是v-bind,通常不管是动态仍是静态,咱们都会采用:。 二、:msg='meat',meat是变量;msg='meat',meat是字符串,:msg="'meat'",meat是字符串 三、子级不能直接改变父级的数据,若是要修改能够将父级的数据修改后赋值给子级的变量,可使用data或者computed
<div id=app> <child :data='aaa' :data1="bbb"></child> //此处,在子组件中左边的是子组件的接收,用props接收,若是是放在数组中每一项就是一个字符串,右边是从父级传递的数据。 </div> <script> let vm=new Vue({ el:'#app', data:{ aaa:'xxxxx', bbb:'yyyyy' } components:{// child:{ props:['data','data1'], template:'<div>{{msg}}</div>', data(){ return {msg:this.data+'zxvv'} }, computed:{ msg:{ get(){ return this.data+'zxvv' } } } } } }) </script>
props
中的validate
:vue
一、props:['xx','yy','zz']; 二、props:{ aa:{ type:[Number,String],//选择值得类型符不符合要求 default:'acac',//默认值 validator(val){//校验函数 return val>200//返回false,校验失败。 } required:true,//表明属性必须填 } }
- 二、子级向父级传递数据(借助于事件)
一、子级$emit后会触发本身身上的某一个自定的方法,这个方法对应的函数在父级的身上。
<div id="app1"> {{datas}} <child @get-data="getData"></child>//自定义方法写在本身身上,右边的是父级对应方法的函数 </div> let vm1 = new Vue({ el: '#app1', data: { datas: '',//用来接收本身传递的空数据 }, methods: { getData(msg){//接受的参数就是从子级传递过来的数据 this.datas = msg; } }, components: { child: { template: `<div><button @click="say">{{msg}}</button></div>`,//绑定触发事件 methods: { say(){//触发事件,以及自定义方法 this.$emit('get-data', this.msg);//这里的this指的是当前子组件 } }, data(){ return { msg: 'xxx' } } } } })
- 三、兄弟之间传递数据
一、兄弟之间传递数据须要借助于事件车,经过事件车的方式传递数据eventBus 二、建立一个Vue的实例,让各个兄弟共用同一个事件机制。 三、传递数据方,经过一个事件触发bus.$emit(方法名,传递的数据)。 四、接收数据方,经过mounted(){}触发bus.$on(方法名,function(接收数据的参数){用该组件的数据接收传递过来的数据}),此时函数中的this已经发生了改变,可使用箭头函数。
具名slot,经过组件传入模板,每一个模板指定是slot名字,这个名字和定制模板匹配到,会替换定制的模板。 slot是vue中提供的一个标签,用来作模板定制的。属性,事件,定制模板组成了组件的API。 **使用slot分发内容** 为了让组件能够组合,咱们须要一种防暑混合父组件的内容与子组件本身的模板。这个过程被称做内容分发(transclusion),vue.js实现了一个内容分发API,使用特殊的<slot>元素做为原始内容的插槽。 **编译做用域** 父组件模板的内容在父组件做用域内编译;子组件模板的内容在子组件做用域内编译。 **单个slot** 除非子组件模板包含至少一个 <slot> 插口,不然父组件的内容将会被丢弃。当子组件模板只有一个没有属性的 slot 时,父组件整个内容片断将插入到 slot 所在的 DOM 位置,并替换掉 slot 标签自己。 最初在 <slot> 标签中的任何内容都被视为备用内容。备用内容在子组件的做用域内编译,而且只有在宿主元素为空,且没有要插入的内容时才显示备用内容。 **具名slot** <slot>元素能够用有个特殊的属性name来配置如何分发内容。多个slot能够有不一样的名字。具名slot将匹配内容片断中对应slot特性的元素。但任然能够有一个匿名slot,它是默认的slot,做为找不到匹配的内容片断的备用插槽。若是没有默认的slot,这些找不到匹配的内容将被抛弃。
组件在它的模板内能够递归地调用本身。recursive 递归组件,本身调用本身,必须有中断条件。 默认状况下,递归组件是不会执行的,要制定name属性(只在局部组件中须要添加),全局逐渐不须要加name属性。
is能够指定当前标签内能够指定插入什么元素,能够防止解析出错。 radio中默认没有绑定数据,要给value值,这个value值会映射到radio上
<keep-alive> <component :is="rad"></component><!--缓存组件的上一次状态,防止每次切换时都须要渲染组件--> </keep-alive>