Logo

vue设置全局变量:让你的数据无处不在!

photo

2023年10月24日

前言

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

vuexvue 的官方状态管理库,可以用于管理全局状态。通过在 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

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

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>

页面展示

在这里插入图片描述

橙子主题打折出售

其实我不卖,主要是这里是放广告的,所以就放了一个
毕竟主题都没做完,卖了也是坑.

购买它
本文为原创文章,请注意保留出处!

热门文章

无法握住的故土 在我们心灵最温暖的角落,总有一寸土地是属于故乡的。虽然我们看似已远离故土,可骨子里对故乡的依恋却是从未冷却过。我们无论漂泊他乡,还是在繁华都市平步青云,可故乡的悠悠情思总会潜入梦乡与你缠绵。是儿时那一缕缕茉莉的清香萦绕在梦境,也是邻家那已锈迹斑斑的铁壶里,开出艳丽的花儿在梦的边缘摇曳。故土就这样根深蒂固地在我们的灵魂深处烙下深深的印记。 作者:Pastore Antonio
1596 浏览量
EWS(Exchange Service)基本使用(获取个人会议,会议室会议内容,会议室列表,发送会议,修改会议,删除会议) 最近公司要求和exchange服务对接,所以稍微研究了一下官方文档,做出以下总结,欢迎大家补充。先...EWS(ExchangeService)基本使用(获取个人会议,会议室会议内容,会议室列表,发送会议,修改会议,删除会议) 作者:Pastore Antonio
1585 浏览量
Sql Server 部署SSIS包完成远程数据传输 本篇介绍如何使用SSIS和作业完成自动更新目标数据任务。**温馨提示:如需转载本文,请注明...SqlServer部署SSIS包完成远程数据传输 作者:Pastore Antonio
1579 浏览量
SQL Server AG集群启动不起来的临时自救大招 背景前晚一朋友遇到AG集群发生来回切换不稳定的情况,情急之下,朋友在命令行使用命令重启WSFC集群...SQLServerAG集群启动不起来的临时自救大招 作者:Pastore Antonio
1573 浏览量
windows 下安装 memcahce 官网上并未提供Memcached的Windows平台安装包,我们可以使用以下链接来下载,你需...windows下安装memcahce 作者:Pastore Antonio
1566 浏览量