# 组件 组件 (Component) 是 Vue.js 最强大的功能之一。组件可以扩展 HTML 元素,封装可重用的代码。在较高层面上,组件是自定义元素,Vue.js 的编译器为它添加特殊功能。在有些情况下,组件也可以表现为用 `is` 特性进行了扩展的原生 HTML 元素。 所有的 Vue 组件同时也都是 Vue 的实例,所以可接受相同的选项对象(除了一些根级特有的选项)并提供相同的生命周期钩子。 ## 使用组件 ### 全局注册 ```js Vue.component('my-component', { template: '
A custom component!
' }); ``` ### 局部注册 ```js var Child = { template: '
A custom component!
' }; new Vue({ components: { // 将只在父组件模板中可用 'my-component': Child } }) ``` ### DOM 解析限制 当使用 DOM 作为模板时 (例如,使用 `el` 选项来把 Vue 实例挂载到一个已有内容的元素上),你会受到 HTML 本身的一些限制,因为 Vue 只有在浏览器解析、规范化模板之后才能获取其内容。尤其要注意,像 `ul`、`ol`、`table`、`select` 这样的元素里允许包含的元素有限制,而另一些像 `option` 这样的元素只能出现在某些特定元素的内部。 ```html ... // 自定义组件 my-row 会被当作无效的内容 // 变通的方案是使用特殊的 is 特性
``` 应当注意,如果使用来自以下来源之一的字符串模板,则没有这些限制: * `