Vue.extend实现挂载到实例-创新互联

本篇文章给大家分享的是有关Vue.extend实现挂载到实例,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

成都创新互联公司专注于企业营销型网站建设、网站重做改版、河源网站定制设计、自适应品牌网站建设、H5建站商城网站定制开发、集团公司官网建设、成都外贸网站制作、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为河源等各大城市提供网站开发制作服务。

根据官网的说法,Vue.extend:是使用基础 Vue 构造器,创建一个“子类”。参数是一个包含组件选项的对象。

// 创建构造器
var Profile = Vue.extend({
 template: '

{{firstName}} {{lastName}} aka {{alias}}

',  data: function () {   return {    firstName: 'Walter',    lastName: 'White',    alias: 'Heisenberg'   }  } }) // 创建 Profile 实例,并挂载到一个元素上。 new Profile().$mount('#mount-point')

最终结果如下:

Walter White aka Heisenberg

感觉这样写不太美观

于是改为下面这样写:

在文件夹./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实现挂载到实例,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注创新互联行业资讯频道。


网页题目:Vue.extend实现挂载到实例-创新互联
文章路径:http://pwwzsj.com/article/ccshsh.html

其他资讯