Vue.extend实现挂载到实例上的方法
本文实例讲述了Vue.extend实现挂载到实例上的方法。分享给大家供大家参考,具体如下:
这里主要是做个笔记
根据官网的说法,Vue.extend:是使用基础Vue构造器,创建一个“子类”。参数是一个包含组件选项的对象。
官网的用法是:
//创建构造器
varProfile=Vue.extend({
template:'{{firstName}}{{lastName}}aka{{alias}}
',
data:function(){
return{
firstName:'Walter',
lastName:'White',
alias:'Heisenberg'
}
}
})
//创建Profile实例,并挂载到一个元素上。
newProfile().$mount('#mount-point')
最终结果如下:
WalterWhiteakaHeisenberg
感觉这样写不太美观
于是改为下面这样写:
在文件夹./src/component/expend,新建两个文件:main.js和main.vue
main.vue就是你的组件,爱怎么写怎么写
main.js是把组件挂载到实例上,代码如下:
importVuefrom'Vue'
importMainfrom'./main.vue'
letBuilder=Vue.extend(Main)
exportdefault{
install(vue){
vue.prototype.$YOURNAME=this.getComponent
},
getComponent(param){
letinstance=newBuilder({
propsData:{param}
})
instance.vm=instance.$mount()
document.body.appendChild(instance.vm.$el)
returninstance
}
}
在入口文件main.js,添加代码:
importVuefrom'Vue' importmyComponentfrom'./src/component/expend/main.js' Vue.use(myComponent)
然后在页面中就可以这样使用了:
this.$YOURNAME(param)
希望本文所述对大家vue.js程序设计有所帮助。