本篇资料来于官方文档:java
http://cn.vuejs.org/guide/components.html
app
本文是在官方文档的基础上,更加细致的说明,代码更多更全。ide
简单来讲,更适合新手阅读函数
(二十五)组件的定义post
①组件的做用:
【1】扩展HTML元素,封装可重用的代码;测试
【2】组件是自定义元素,Vuejs的编译器能够为其添加特殊的功能;ui
【3】某些状况下,组件能够是原生HTML元素的形式,以is的方式扩展。
②写一个标准的组件:
分为如下几步:
【1】挂载组件的地方,须要是Vue实例所渲染的html元素,具体来讲,好比上面的<div id=”app”></div>这样的html元素及他的子节点;
【2】定义一个组件,用
var 变量名 = Vue.extend({template:”这里是html的模板内容”})
这样的形式建立,例如:
- var btn = Vue.extend({
- template: "<button>这是一个按钮</button>"
- })
【3】将定义的组件注册到Vue实例上,这会让指定标签,被组件的内容所替代。
如代码:
- Vue.component("add-button", btn);
具体而言,每个如下这样的标签(在Vue的根实例范围内的)
- <add-button></add-button>
会被
所替代。
【4】以上方法是全局注册(每一个Vue实例的add-button标签都会被咱们定义的所替代);
解决办法是局部注册。
如代码:(这是是设置了template属性,也能够在没有这个属性的时候,在<div id=”app”></div>标签内放置<add-button></add-button>标签
- <div id="app">
- </div>
- <script>
- //定义一个组件
- var btn = Vue.extend({
- template: "<button>这是一个按钮</button>"
- })
-
- Vue.component("add-button", btn);
-
- //建立根实例,也就是说让Vue对这个根生效
- var vm = new Vue({
- el: '#app',
- template: "<add-button></add-button>"
- });
- </script>
③局部注册组件:
简单来讲,只对这一个Vue实例生效,具体作法是,在注册那一步,跳过;
而后在声明Vue实例的时候,将添加到components这个属性中(他是一个对象,以KV形式放置)(注意,这个单词多一个s)
如代码:
- <div id="app">
- </div>
- <script>
- //定义一个组件
- var btn = Vue.extend({
- template: "<button>这是一个按钮</button>"
- })
-
- //建立根实例,也就是说让Vue对这个根生效
- var vm = new Vue({
- el: '#app',
- template: "<add-button></add-button>",
- components: {
- "add-button": btn
- }
- });
- </script>
注:
根据官方教程,这种方法(指局部注册),也适用于其余资源,好比指令、过滤器和过渡。
④步骤简化:
【1】定义组件和注册组件结合起来一步完成:
- Vue.component("add-button", {
- template: "<button>这是一个按钮</button>"
- });
【2】局部注册时,定义和注册一步完成:
- var vm = new Vue({
- el: '#app',
- template: "<add-button></add-button>",
- components: {
- "add-button": {
- template: "<button>这是一个按钮</button>"
- }
- }
- });
⑤data属性
直接给组件添加data属性是不能够的(无效);
缘由在于,假如这么干,那么组件的data属性有多是一个对象,而这个对象也有多是外部传入的(例如先声明一个对象,而后这个对象做为data的值),可能致使这个组件的全部副本,都共享一个对象(那个外部传入的),这显然是不对的。
所以,data属性应该是一个函数,而后有一个返回值,这个返回值做为data属性的值。
且这个返回值应该是一个全新的对象(即深度复制的,避免多个组件共享一个对象);
如代码:
- var vm = new Vue({
- el: '#app',
- template: "<add-button></add-button>",
- components: {
- "add-button": {
- template: "<button>这是一个按钮{{btn}}</button>",
- data: function () {
- return {btn: "123"};
- }
- }
- }
- });
另外,假如这样的话,btn的值是同样的(由于他们实际上仍是共享了一个对象)
- <div id="app">
- </div>
- <div id="app2">
- </div>
- <script>
- var obj = {btn: "123"};
- var vm = new Vue({
- el: '#app',
- template: "<add-button></add-button>",
- components: {
- "add-button": {
- template: "<button>这是一个按钮{{btn}}</button>",
- data: function () {
- return obj;
- }
- }
- }
- });
-
- obj.btn = "456";
- var vm2 = new Vue({
- el: '#app2',
- template: "<add-button></add-button>",
- components: {
- "add-button": {
- template: "<button>这是一个按钮{{btn}}</button>",
- data: function () {
- return obj;
- }
- }
- }
- });
- </script>
注:
el属性用在Vue.extend()中时,也须是一个函数。
⑥is特性:
【1】按照官方教程,一些HTML元素对什么元素能够放在它之中是有限制的;
但实际我本身测试没发现问题,因此不明白。
【2】给个URL吧,若是真出问题了我再回头研究。
http://cn.vuejs.org/guide/components.html#u6A21_u677F_u89E3_u6790