本篇文章给大家分享的是有关Vue.extend实现挂载到实例,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
根据官网的说法,Vue.extend:是使用基础 Vue 构造器,创建一个“子类”。参数是一个包含组件选项的对象。
<div id="mount-point"></div>
// 创建构造器 var Profile = Vue.extend({ template: '<p>{{firstName}} {{lastName}} aka {{alias}}</p>', data: function () { return { firstName: 'Walter', lastName: 'White', alias: 'Heisenberg' } } }) // 创建 Profile 实例,并挂载到一个元素上。 new Profile().$mount('#mount-point')
最终结果如下:
<p>Walter White aka Heisenberg</p>
感觉这样写不太美观
于是改为下面这样写:
在文件夹./src/component/expend,新建两个文件:main.js和main.vue
main.vue就是你的组件,爱怎么写怎么写
main.js是把组件挂载到实例上,代码如下:
import Vue from 'Vue' import Main from './main.vue' let Builder = Vue.extend(Main) export default { install (vue) { vue.prototype.$YOURNAME = this.getComponent }, getComponent (param) { let instance = new Builder({ propsData: { param } }) instance.vm = instance.$mount() document.body.appendChild(instance.vm.$el) return instance } }
在入口文件main.js,添加代码:
import Vue from 'Vue' import myComponent from './src/component/expend/main.js' Vue.use(myComponent)
然后在页面中就可以这样使用了:
this.$YOURNAME(param)
以上就是Vue.extend实现挂载到实例,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。