当前位置:首页 » 《我的小黑屋》 » 正文

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

18 人参与  2024年04月01日 17:10  分类 : 《我的小黑屋》  评论

点击全文阅读


前言

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>

页面展示

在这里插入图片描述


点击全文阅读


本文链接:http://zhangshiyu.com/post/89130.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1