组件的局部注册
在 Vue 实例中,使用 componen饱选项可以局部注册组件,注册后的组件只有在该实例作用域
下有效。组件中也可以使用 components 选项来注册组件,使组件可以嵌套。
注意:
局部注册的组件在其子组件中不可用。
方法
1.定义组件
var ComponentA = { /* ... */ }
var ComponentB = { /* ... */ }
var ComponentC = { /* ... */ }
2.在创建Vue实例时,增加components选项,在components选项中注册需要用到的组件:
new Vue({
el: '#app',
components: {
'component-a': ComponentA,
'component-b': ComponentB,
}
});
其中,针对components对象中的每个属性而言,其属性名(这里即component-a)就是自定义元素的名字,属性值为需要注册的组件对象。
代码示例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!--引入最新的vue稳定版本-->
<script type="text/javascript" src="https://unpkg.com/vue/dist/vue.min.js"></script>
</head>
<body>
<!--组件的局部注册-->
<div id="app">
<my-component></my-component>
</div>
<script>
//创建一个组件
var child={
template: '<div>局部注册组件的内容</div>'
}
//创建一个vue实例,并把组件注册到该vue实例上
//局部注册到vue实例上,可以通过在vue实例的components选项进行局部注册
var vue = new Vue({
el: '#app',
components: {
'my-component':child
}
});
</script>
</body>
</html>
运行结果:

组件的局部注册