一、组件定义
组件 (Component) 是 Vue.js 最强大的功能之一。组件可以扩展 HTML 元素,封装可重用的代码。在较高层面上,组件是自定义元素,Vue.js 的编译器为它添加特殊功能。在有些情况下,组件也可以表现为用is 特性进行了扩展的原生 HTML 元素。所有的 Vue 组件同时也都是 Vue 的实例,所以可接受相同的选项对象 (除了一些根级特有的选项) 并提供相同的生命周期钩子。
二、自定义组件
1、全局组件
注册全局组件:可以使用可以使用 Vue.component(tagName, options)
1 Vue.component('my-component', {
2 // 选项
3 })
组件在注册之后,便可以作为自定义元素 在一个实例的模板中使用。注意确保在初始化根实例之前注册组件:
1 <div id="example">
2 <my-component></my-component>
3 </div>
测试实例:
1 <!DOCTYPE html>
2 <html>
3 <head>
4 <meta charset="utf-8">
5 <title>Vue 测试实例 - 全局组件</title>
6 <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
7 </head>
8 <body>
9 <div id="app">
10 <!-----引用组件----->
11 <my-component></my-component>
12 </div>
13
14 <script>
15 // 注册
16 Vue.component('my-component', {
17 template: '<h3>我是全局组件!</h3>'
18 })
19 // 创建根实例
20 new Vue({
21 el: '#app'
22 })
23 </script>
24 </body>
25 </html>
2、局部组件
你不必把每个组件都注册到全局。你可以通过某个 Vue 实例/组件的实例选项 components注册仅在其作用域中可用的组件:
1 var Child = {
2 template: '<h3>我是局部组件!</h3>'
3 }new Vue({ // ... components: { // <my-component> 将只在父组件模板中可用 'my-compo