0


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

前言

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'});exportdefault globalData;

然后,在任何组件中,我们可以通过导入

globalData

并访问

globalData.globalVar

来访问该全局变量。

任意一个组件内

<template><div>
    {{globalData.globalVar}}
  </div></template><script>import globalData from"@/main";exportdefault{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)exportdefaultnewVuex.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>exportdefault{mounted(){
    localStorage.setItem("globalVar","Hello World");},};</script>

然后,在其他组件中,我们可以通过

localStorage.getItem('globalVar')

来访问该全局变量。

**

b.vue

**

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

页面展示

在这里插入图片描述

标签: 前端 vue

本文转载自: https://blog.csdn.net/Shids_/article/details/131418080
版权归原作者 水星记_ 所有, 如有侵权,请联系我们删除。

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

还没有评论