您的位置:首页 > 产品设计 > UI/UE

Vue.extend构造器

2018-04-03 14:01 351 查看
转载地址:https://blog.csdn.net/Dear_Mr/article/details/72627214

1.简单介绍

Vue.extend(options)参数:对象用法:使用Vue构造器,创建一个“子类”,参数是一个包含组件选项的对象,其中,
data
选项中必须是函数描述:
Vue.extend
返回的是一个“扩展实例构造器”,也就是预设了部分选项的Vue的实例构造器,它常常服务于
Vue.component
用来生成组件,可以简单理解为当在模板中遇到该组件作为标签的自定义元素时,会自动调用“扩展实例构造器”来生产组件实例,并挂在到自定义元素上

2.简单举例

自定义无参数标签

下面的代码中的author就是返回的“扩展实例构造器”
var author = Vue.extend({
template: "<p><a :href='url'>{{author}}</a></p>",
data : function() {
return {
author : 'vamous',
url : 'http://blog.csdn.net/Dear_Mr/article/details/72614370'
}
}
});
1
2
3
4
5
6
7
8
9
对应的html如下:
<author></author>
1
此时的页面必然是没有任何效果的,因为扩展实例构造器还需要挂载,如下
new author().$mount('author');
1
使用propsData
var author = Vue.extend({
template: "<p><a :href='url'>{{author}} & {{name}}</a></p>",
data : function() {
return {
author : 'vamous',
url : 'http://blog.csdn.net/Dear_Mr/article/details/72614370'
}
},
props : ['name']
});

new author({propsData: {name : 'dear_mr'}}).$mount('#author');
可以利用propsData传递参数

挂载在普通标签上

返回的扩展实例构造器的方式和上面还是一样的,只是html里不再是自定义标签,而是一个普通标签,比如
div
<div id="author"></div>
1
new author().$mount('author');
1
其实对于同一个扩展构造器而言,它的每一个实例其实是可以挂载到不同的标签上的,比如我可以这样
new author().$mount('#author');
new author().$mount('author');
1
2
这两个标签的内容会一同显示,结果一样Vue官方文档:https://cn.vuejs.org/v2/api/#Vue-extend
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  vue2.0 封装组件 extend