vue3 如何定义全局变量

Posted 程序员超时空

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue3 如何定义全局变量相关的知识,希望对你有一定的参考价值。

在vue2中,我们知道vue2.x是使用Vue.prototype.$xxxx=xxx来定义全局变量,然后通过this.$xxx来获取全局变量。

但是在vue3中,这种方法显然不行了。因为vue3中在setup里面我们是无法获取到this的,因此按照官方文档我们使用下面方法来定义全局变量:

首先在main.js里写一个我们要定义的全局变量,比如一个系统id吧

app.config.globalProperties.$systemId = "10"

现在在页面里需要使用这个变量,只需要从vue中引入getCurrentInstance即可,注意不能在页面中使用this.

import  getCurrentInstance  from "vue";
const systemId = getCurrentInstance()?.appContext.config.globalProperties.$systemId
console.log(systemId);//控制台可以看到输出了10

如果大家还有其他的方法欢迎大家评论区留言或者私信我,希望这篇博客可以帮助到大家。

以上是关于vue3 如何定义全局变量的主要内容,如果未能解决你的问题,请参考以下文章

vue3中使用scss全局变量

2022-03-03 vue3中使用全局变量

前端VUE3 在原型上挂载全局方法变量

vue3.2 setup 之局部自定义指令

vue3.2 setup 之局部自定义指令

全局属性的“功能”类型上不存在 Vue3 属性“x”