目录javascript
// for in遍历的是取值关键 | for of遍历的是值
概念:html
, css
, js
的集合体命名 ,用该名字复用html
,css
,js
组合成的集合体 体现了复用性
css
// 根组件:new Vue() 生产的组件
// 局部组件: 组件名 = {} , {}内部采用的是vue语法
// 全局组件: Vue.component('组件名', {}) , {}内部采用的是vue语法
1.组件都有管理组件html
页面的结果的 template
实例成员, template
中有且只有一个根标签html
挂载点本质是被组价template模块进行替换的占位符vue
// 总结: 根组件,能够不明确template, template默认采用挂载点页面结构:若是设置的template, 挂载点内部的内容无效,由于会被替换 // 解释: html, body 标签不能被替换,因此不能为挂载点. // template 渲染真实dom 替换虚拟dom
2.根组件都是做为最顶层父组件, 局部与全局组价做为子组价, 也能够成为其余局部与全局的父组件java
3.子组件的数据须要隔离(数据组件化,每个组件拥有本身的数据的独立名称空间)dom
4.局部组件必须注册后才能使用,全局不须要注册,提倡使用局部组件组件化
5.组件中出现的全部变量(模板中,逻辑中) 由该组价本身提供管理this
6.局部 全局 根组件 都是一个vue
实例, 一个实对应一套html
, css
, js
结构, 因此实例就是组件code
// 声明局部组件:局部组件要在其父在组件中注册才能使用 // 1.声明组件 2.注册组件 3.渲染组件
声明:component
let localTag = { template:'<a>pass</a>', methods:{ pass } }
// 注册在components:{}里注册 key 和 value 若是同样能够简写 key
Vue({ el:'xx', components:{ localTag } })
可是在html
中的tag
不支持大写 因此用 - 来代替
<local-tag></local-tag>
// 声明局部组件:局部组件要在其父在组件中注册才能使用 // 1.声明组件 2.渲染组件
Vue.component('组件名', { template:'<a>pass</a>', methods:{ pass } } )
<组件名></组件名>
每一个组件的数据应该是隔离的 可是data里的数据你们访问的都是同一个 因此要让他产生本身的局部做用域
let localTag = { data:funttion(){ return { num:0 } data(){ return { num:0 } // 数据须要组件化,做为方法的返回值(方法执行后会产生一个局部做用域) } } template:'<a>{{num}}</a>', methods:{ pass } }
// 局部或全局取件,一个组件可能会被重复使用屡次, 每一个组件都应该有本身独立的名称空间
// 数据须要组件化,做为方法的返回值(return{} 里面放入数据就行)
// 1)子组件能够经过props自定义组件属性(采用反射机制,须要填写字符串,可是使用时能够直接做为变量) // 2)子组件会在父组件中渲染,渲染时,将父组件的变量绑定给子组件的自定义属性,将能够将变量值传递给子组件
关键字:props
在子标签中规定自定义标签 而后在子组件中填写props:['xx']
来获取对应的值
<text-tag :abc="xxx"></Text-tag>
let textTag ={ props: ['xxx'] };
同时, 在里面调用该值也须要 使用属性绑定来获取 由于传来的是变量!
// 自定义组件标签的事件 // 自定义事件是属于子组件的,子组件在父组件中渲染并绑定事件方法,因此事件方法由父组件来实现 // 子组件如何触发自定义事件:this.$emit('自定义事件名', 触发事件回调的参数们) // 子组件触发自定义事件,携带出子组件的内容,在父组件中实现自定义事件的方法,拿到子组件传递给父组件的消息
子组件如何触发自定义事件:
<!--this.$emit('自定义事件名', 触发事件回调的参数们)-->
<tag @action="actionFn"></tag>
父组件的methods
方法
methods: { actionFn(a, b, c) { // console.log('触发了', a, b, c); this.h1 = a; this.h3 = b; }, }
子组件的methods
方法
methods: { changeTitle() { if (this.t1 && this.t2) { this.$emit('action', this.t1, this.t2); } } }