zoukankan      html  css  js  c++  java
  • Vue 基础知识之 Vue.extend

    Vue.extend 属于 Vue 的全局 API,在实际业务开发中我们很少使用,因为相比常用的 Vue.component 写法使用 extend 步骤要更加繁琐一些。但是在一些独立组件开发场景中,Vue.extend + $mount 这对组合是我们需要去关注的。

    官方文档

    学习开始之前我们先来看一下官方文档是怎么描述的。

    Vue.extend( options )

    • 参数

      • {Object} options
    • 用法

      使用基础 Vue 构造器,创建一个“子类”。参数是一个包含组件选项的对象。

      data 选项是特例,需要注意 - 在 Vue.extend() 中它必须是函数

      <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>
      
    • 参考组件

    可以看到,extend 创建的是 Vue 构造器,而不是我们平时常写的组件实例,所以不可以通过 new Vue({ components: testExtend }) 来直接使用,需要通过 new Profile().$mount('#mount-point') 来挂载到指定的元素上。

    为什么使用 extend

    在 vue 项目中,我们有了初始化的根实例后,所有页面基本上都是通过 router 来管理,组件也是通过 import 来进行局部注册,所以组件的创建我们不需要去关注,相比 extend 要更省心一点点。但是这样做会有几个缺点:

    1. 组件模板都是事先定义好的,如果我要从接口动态渲染组件怎么办?
    2. 所有内容都是在 #app 下渲染,注册组件都是在当前位置渲染。如果我要实现一个类似于 window.alert() 提示组件要求像调用 JS 函数一样调用它,该怎么办?

    这时候,Vue.extend + vm.$mount 组合就派上用场了。

    简单示例

    我们照着官方文档来创建一个示例:

    import Vue from 'vue'
    
    const testComponent = Vue.extend({
      template: '<div>{{ text }}</div>',
      data: function () {
        return {
          text: 'extend test'
        }
      }
    })
    

    然后我们将它手动渲染:

    const extendComponent = new testComponent().$mount()
    

    这时候,我们就将组件渲染挂载到 body 节点上了。

    我们可以通过 $el 属性来访问 extendComponent 组件实例:

    document.body.appendChild(extendComponent.$el)
    

    如果想深入掌握 extend 知识,不妨做一个 alert 组件来实现类似于原生的全局调用。

    加油!

  • 相关阅读:
    UEditor中多图上传的bug
    Mysql 5.5 数据库命令大全
    Android学习书籍
    众方中继使用说明
    MyEclipse 2015优化技巧
    Android studio1.3.1 快捷键
    你有没有这样的猜疑?
    右键新建没有Word_Excel_PowerPoint的解决方法
    电脑清理桌面快捷图标小箭头
    Spring3.1+Hibernate3+Struts2的最新整合所需要的jar包
  • 原文地址:https://www.cnblogs.com/hentai-miao/p/10271652.html
Copyright © 2011-2022 走看看