一、什么是组件?
组件 (Component) 是 Vue.js 最强大的功能之一。组件可以扩展 HTML 元素,封装可重用的代码。在较高层面上,组件是自定义元素,Vue.js 的编译器为它添加特殊功能。在有些情况下,组件也可以表现为用 is 特性进行了扩展的原生 HTML 元素。
二、创建全局组件
方式一:
1、使用 Vue.extend 创建组件
var com1 = Vue.extend({
// 通过 template 属性,指定了组件要展示的 HTML 结构
template: '<h3>这是使用 Vue.extend 创建的组件</h3>'
})
2、使用 Vue.component('组件的名称', 创建出来的组件模板对象) 注册组件
Vue.component('myCom1', com1)
注意:如果使用 Vue.Component 注册全局组件的时候,组件的名称使用了驼峰命名,则在引用组件的时候需要把大写的驼峰改为小写的字母,同时,两个单词之前,使用 “-” 链接。如果不使用则直接拿名称来使用即可。
方式二:
直接使用 Vue.component 的方式创建
Vue.component('mycom2', {
template: '<div><h3>这是直接使用 Vue.component 创建出来的组件</h3>
<span>123</span></div>'
})
方式三:
1、被控制的 #app 外面,使用 template 元素,定义组件的 HTML 模板结构
<template id="tmpl">
<div>
<h1>这是通过 template 元素,在外部定义的组件结构</h1>
<h4>好用,不错!</h4>
</div>
</template>
2、使用 id 注册组件
Vue.component('mycom3', {
template: '#tmpl'
})
三、创建局部组件
局部组件的创建和全局组件的创建方法一样。唯一区别的是,局部组件是在 Vue实例中定义的。