Vue3 全局 API 转移详解

目录

[一、什么是全局 API?](#一、什么是全局 API?)

[二、Vue3 为什么要转移?](#二、Vue3 为什么要转移?)

[三、Vue3 的全局 API 转移](#三、Vue3 的全局 API 转移)

[四、常见 API 的迁移对照表](#四、常见 API 的迁移对照表)

五、特殊说明

六、总结


在 Vue2 到 Vue3 的升级过程中,除了响应式系统、组件写法等发生了变化,全局 API 的转移也是一个非常重要的点。很多初学者在迁移代码时会遇到报错,就是因为 Vue3 不再像 Vue2 那样把所有 API 挂在 Vue 构造函数上了。

本文就来详细讲解一下 Vue 的全局 API 转移


一、什么是全局 API?

在 Vue2 中,我们经常会写:

javascript 复制代码
import Vue from 'vue'

// 全局配置
Vue.config.productionTip = false

// 全局注册组件
Vue.component('MyComponent', {...})

// 全局注册指令
Vue.directive('focus', {...})

// 全局使用插件
Vue.use(MyPlugin)

// 创建实例
new Vue({
  render: h => h(App),
}).$mount('#app')

可以看到,所有的 API(configcomponentdirectiveuse 等)都挂在 Vue 构造函数上。


二、Vue3 为什么要转移?

在 Vue3 中,框架的设计理念更加 模块化可树摇(Tree-shaking)

如果还把所有 API 都集中在 Vue 上,会导致以下问题:

  1. 包体积大:没用到的 API 也会被打包。

  2. 类型推导差:不利于 TS 类型支持。

  3. 逻辑不清晰:应用级别的配置与组件实例混在一起。

因此,Vue3 把全局 API 拆分成了更清晰的模块。


三、Vue3 的全局 API 转移

在 Vue3 中,所有的应用级 API 都转移到了由 createApp 创建的 应用实例(app 实例) 上。

示例:

javascript 复制代码
import { createApp } from 'vue'
import App from './App.vue'

const app = createApp(App)

// 全局配置
app.config.globalProperties.$http = () => {}

// 全局注册组件
app.component('MyComponent', {...})

// 全局注册指令
app.directive('focus', {...})

// 全局使用插件
app.use(MyPlugin)

// 挂载应用
app.mount('#app')

对比 Vue2,你会发现:

Vue.xxx 变成了 app.xxx


四、常见 API 的迁移对照表

Vue2 写法 Vue3 写法
Vue.config app.config
Vue.component app.component
Vue.directive app.directive
Vue.mixin app.mixin
Vue.use app.use
Vue.prototype app.config.globalProperties

这样设计的好处是:每个应用实例都可以有自己独立的配置,不会互相影响,非常适合 多应用场景


五、特殊说明

  1. Vue.extend 被移除

    Vue3 推荐使用 defineComponent 来定义组件。

    javascript 复制代码
    import { defineComponent } from 'vue'
    
    export default defineComponent({
      props: { msg: String },
      setup(props) {
        return () => <div>{ props.msg }</div>
      }
    })
  2. Vue.setVue.delete 移除

    在 Vue3 的 Proxy 响应式系统下,已经不需要 set/delete 这种强制 API 了。

  3. 全局过滤器 Vue.filter 被移除

    Vue3 建议用 方法计算属性 来替代。


六、总结

  • Vue2:全局 API 都挂在 Vue 构造函数上。

  • Vue3:全局 API 都转移到了 应用实例 app 上。

  • 迁移规则:Vue.xxx → app.xxx

  • 移除了一些过时 API(Vue.extendVue.setVue.filter 等)。

这就是所谓的 Vue 全局 API 转移 ,如果面试官问到,可以从 原因、变化、示例、迁移方式 四个维度回答。


一句话精简版回答(面试常用):

在 Vue2 中,全局 API 挂在 Vue 上;在 Vue3 中,这些 API 都迁移到由 createApp 创建的应用实例上,比如 Vue.useapp.useVue.componentapp.component,这样做是为了支持多应用和更好的 Tree-shaking。

相关推荐
艾小码6 小时前
从零到一:这篇JavaScript指南让你成为独立开发者
前端·javascript
月下点灯6 小时前
🏮一眼就会🗂️大文件分片上传,白送前后端全套功法
javascript·typescript·node.js
顾安r11 小时前
11.8 脚本网页 星际逃生
c语言·前端·javascript·flask
Hello.Reader12 小时前
Data Sink定义、参数与可落地示例
java·前端·网络
im_AMBER12 小时前
React 17
前端·javascript·笔记·学习·react.js·前端框架
一雨方知深秋12 小时前
2.fs模块对计算机硬盘进行读写操作(Promise进行封装)
javascript·node.js·promise·v8·cpython
谷歌开发者13 小时前
Web 开发指向标 | Chrome 开发者工具学习资源 (六)
前端·chrome·学习
一晌小贪欢13 小时前
【Html模板】电商运营可视化大屏模板 Excel存储 + 一键导出(已上线-可预览)
前端·数据分析·html·excel·数据看板·电商大屏·大屏看板
发现你走远了13 小时前
连接模拟器网页进行h5的调试(使用Chrome远程调试(推荐)) 保姆级图文
前端·chrome
街尾杂货店&14 小时前
css - 实现三角形 div 容器,用css画一个三角形(提供示例源码)简单粗暴几行代码搞定!
前端·css