vue设置全局变量5种方法(让你的数据无处不在)

 更新时间:2023年11月08日 14:57:11   作者:水星记_  
这篇文章主要给大家介绍了关于vue设置全局变量的5种方法,通过设置的方法可以让你的数据无处不在,在项目中经常会复用一些变量和函数,比如用户的登录token,用户信息等,这时将它们设为全局的就显得很重要了,需要的朋友可以参考下

前言

在 vue 开发中,如何设置全局变量是一个关键问题。本文将介绍多种方法,帮助大家轻松实现全局变量的共享,提升 vue 项目的开发效率。让我们一起来探索这些方法,为你的 vue 项目带来更好的开发体验。

方法一:使用 Vue.prototype

通过在 vue 的原型上定义属性,可以在所有组件中访问该属性。例如,我们可以在 main.js 文件中添加以下代码:

main.js文件

Vue.prototype.$globalVar = 'Hello World';

然后,在任何组件中,我们都可以通过 this.$globalVar 来访问该全局变量。

任意一个组件内

<template>
  <div>
    {{this.$globalVar}}
  </div>
</template>

页面展示

方法二:使用 Vue.mixin

通过混入(mixin)的方式,可以将一些公共的属性或方法混入到所有组件中。例如,我们可以在 main.js 文件中添加以下代码:

main.js文件

Vue.mixin({
    data() {
        return {
            globalVar: 'Hello World'
        };
    }
});

然后,在任何组件中,我们都可以通过 this.globalVar 来访问该全局变量。

任意一个组件内

<template>
  <div>
    {{this.globalVar}}
  </div>
</template>

页面展示

方法三:使用 Vue.observable

通过 Vue.observable 方法,可以创建一个可响应的对象,该对象可以在所有组件中共享。例如,我们可以在 main.js 文件中添加以下代码:

main.js文件

const globalData = Vue.observable({
  globalVar: 'Hello World'
});
export default globalData;

然后,在任何组件中,我们可以通过导入 globalData 并访问 globalData.globalVar 来访问该全局变量。

任意一个组件内

<template>
  <div>
    {{globalData.globalVar}}
  </div>
</template>

<script>
import globalData from "@/main";
export default {
  data() {
    return {
      globalData,
    };
  },
};
</script>

页面展示

方法四:使用 Vuex

vuex 是 vue 的官方状态管理库,可以用于管理全局状态。通过在 vuex 中定义 state,可以在所有组件中访问该状态。例如,我们可以在 store.js 文件中添加以下代码:

store/index.js文件

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
export default new Vuex.Store({
  state: {
    globalVar: 'Hello World'
  },
  // ......
})

然后,在任何组件中,我们可以通过 this.$store.state.globalVar 来访问该全局变量。

任意一个组件内

<template>
  <div>
    {{this.$store.state.globalVar}}
  </div>
</template>

页面展示

方法五:使用 localStorage 或 sessionStorage

通过将变量存储在 localStorage 或 sessionStorage 中,可以在所有组件中共享该变量。例如,我们可以在某个组件中添加以下代码:

a.vue文件

<template>
  <div></div>
</template>
<script>
export default {
  mounted() {
    localStorage.setItem("globalVar", "Hello World");
  },
};
</script>

然后,在其他组件中,我们可以通过 localStorage.getItem('globalVar') 来访问该全局变量。

b.vue

<template>
  <div>{{title}}</div>
</template>

<script>
export default {
  data() {
    return {
      title: "",
    };
  },
  mounted() {
    const value = localStorage.getItem("globalVar");
    if (value) {
      this.title = value;
    }
  },
};
</script>

页面展示

总结 

到此这篇关于vue设置全局变量5种方法的文章就介绍到这了,更多相关vue设置全局变量内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 用Vue.js在浏览器中实现裁剪图像功能

    用Vue.js在浏览器中实现裁剪图像功能

    在本教程中,我们将探讨如何在浏览器中使用 JavaScript 库来操作图片,为服务器上的存储做准备,并在 Web 程序中使用。我们将使用 Vue.js 而不是原生 JavaScript来完成此操作,需要的朋友可以参考下
    2019-06-06
  • vscode中的vue项目报错Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339)

    vscode中的vue项目报错Property ‘xxx‘ does not exist on type ‘Combin

    这篇文章主要介绍了vscode中的vue项目报错Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Vue3中创建异步组件的流程步骤

    Vue3中创建异步组件的流程步骤

    在现代前端开发中,组件的重用性和异步加载是提升用户体验和优化性能的关键因素,在Vue 3中,创建异步组件变得更为便利,本文将探讨如何在Vue 3中使用setup语法糖来创建异步组件,感兴趣的小伙伴跟着小编一起来看看吧
    2024-09-09
  • Electron+vite+vuetify项目搭建的流程和方法

    Electron+vite+vuetify项目搭建的流程和方法

    最近想用Electron来进行跨平台的桌面应用开发,同时想用vuetify作为组件,于是想搭建一个这样的开发环境,这里分享下Electron+vite+vuetify项目搭建的流程和方法,感兴趣的朋友一起看看吧
    2024-06-06
  • vue使用less报错:Inline JavaScript is not enabled问题

    vue使用less报错:Inline JavaScript is not ena

    这篇文章主要介绍了vue使用less报错:Inline JavaScript is not enabled问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • vue 设置proxyTable参数进行代理跨域

    vue 设置proxyTable参数进行代理跨域

    这篇文章主要介绍了vue 设置proxyTable参数进行代理跨域的相关资料,及代理跨域的概念原理,需要的朋友可以参考下
    2018-04-04
  • vue项目中vue-echarts讲解及常用图表实现方案(推荐)

    vue项目中vue-echarts讲解及常用图表实现方案(推荐)

    这篇文章主要介绍了vue项目中vue-echarts讲解及常用图表方案实现,主要针对代码示例中的内容进行问题讲解,详细代码在文章中给大家提到,需要的朋友可以参考下
    2022-09-09
  • ejsExcel模板在Vue.js项目中的实际运用

    ejsExcel模板在Vue.js项目中的实际运用

    这篇文章主要介绍了ejsExcel模板在Vue.js项目中的实际运用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • Vue body样式修改方式

    Vue body样式修改方式

    这篇文章主要介绍了Vue body样式修改方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • Vue引入jquery实现平滑滚动到指定位置

    Vue引入jquery实现平滑滚动到指定位置

    这篇文章主要介绍了Vue引入jquery实现平滑滚动到指定位置的效果,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
    2018-05-05

最新评论