欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue extend的基本用法(实例详解)

程序员文章站 2022-06-25 13:00:49
vue.extend 属于 vue 的全局 api,在实际业务开发中我们很少使用,因为相比常用的 vue.component 写法使用 extend 步骤要更加繁琐一些。 我们创建v...

vue.extend 属于 vue 的全局 api,在实际业务开发中我们很少使用,因为相比常用的 vue.component 写法使用 extend 步骤要更加繁琐一些。

我们创建vue实例时,都会有一个el选项,来指定实例的根节点,如果不写el选项,那组件就处于未挂载状态。vue.extend 的作用,就是基于 vue 构造器,创建一个‘ 子类 ',它的参数跟new vue的基本一样,但data要跟组件一样,是个函数,再配合$mount,就可以渲染组件,并且挂载到任意指定的节点上,比如body(这是单文件组件做不到的)

下面我们就来看两个例子:

1.在单文件组件中使用

<template>
 <div id="about"></div>
</template>
<script>
import vue from 'vue/dist/vue.js'
var profile = vue.extend({
 template: '<p>{{firstname}} {{lastname}} aka {{alias}}</p>',
 data: function () {
  return {
   firstname: 'walter',
   lastname: 'white',
   alias: 'heisenberg'
  }
 }
})
// 创建 profile 实例,并挂载到一个元素上。
let profile=new profile().$mount();
 
export default {
 mounted(){
  let divid=document.getelementbyid('about');
  divid.appendchild(profile.$el)
 }
}
</script>

这里需要注意几个点:

报错信息

Vue extend的基本用法(实例详解)

如果有小伙伴遇到了这个问题,那么你导入的是

import vue from 'vue'

这个时候只需要修改成即可解决问题

import vue from 'vue/dist/vue.js'

在单文件组件中的挂载问题:

因为这里是通过获取节点的方式添加到某个元素内,所以一定要在钩子函数中挂载,确保当前页面的dom节点加载完成。

mounted(){
  let divid=document.getelementbyid('about');
  divid.appendchild(profile.$el)
 }

2.单独构建js文件

//index.js
 
import vue from 'vue/dist/vue.js'
 
export default function create(node){
  var notiful=vue.extend({
    template:`<p>{{name}}</p>`,
    data(){
      return {
        name:"liuhuas"
      }
    }
  })
  
  var noti=new notiful().$mount();
  document.getelementbyid(node).appendchild(noti.$el);
}

创建完成后我们就可以在任何地方引入这个js文件 ,并执行create方法,注意的是这里的create方法里面也获取了dom,那么就需要在相应的钩子函数中去执行这个方法。

总结

以上所述是小编给大家介绍的vue extend的基本用法,希望对大家有所帮助