Vue 全局变量防刷新优雅实现

编程教程 > WEB > Vue.js (4195) 2024-11-26 14:39:04

1.vue项目中创建global.js


创建global.js放于main.js同级目录(可自己随意放)

export default {
  getToken()
  {
    return window.localStorage.token;
  },
 setToken(token) {
  window.localStorage.token = token;
 },
 getInfo() {
  if (window.localStorage.info)
    return JSON.parse(window.localStorage.info);
  return null;
},
 setinfo(user) {
  window.localStorage.info = JSON.stringify(user);
}
}

 


上面代码分别实现了对象和字符串的存储,由于基于localStorage所以需要H5浏览器支持。
 

 

2 vue项目main.js配置

 

import global from './global';

Vue.prototype.global = global;

其他你的代码
 

3 vue全局变量使用

 

let _self=null;
export default {
    name: "demo-vue",
    created:function(){
     _self=this;
   },
    data() {
    },

    methods: {
         test(){
             var token=_self.global.getToken();
             console.log(token)
         }
    }
  };


遗留一个小问题,localStorage必须手动清除,否则永久存放,也可以试试sessionStorage。如果你有更好的方法,欢迎告知。感谢。


评论
User Image
提示:请评论与当前内容相关的回复,广告、推广或无关内容将被删除。

相关文章
1.vue项目中创建global.js创建global.js放于main.js同级目录(可自己随意放)export default {   getToken()   {     retur...
Vue v-if判断数组长度 searchResultDataList为vue定义的data里面的变量<li  v-if="Object.keys(searchResultDataLis...
vue-router 中 routers 定义写法,讨论 require 的使用与否​首先上 routerindex.jsimport Vue from 'vue'import Router f...
一、函数式写法在vue2中,computed 写法:computed:{ sum(){ return this.num1+ this.num2 }} vue 3
前言Vue3 + Vite 打包静态资源使用相对路径 默认配置打包后文件预览相对路径绝对路径 Vue3 静态资源相对路径打包配置方法: 在defineConfi
vue打包会把vue相关的组件打包到一个文件vendor.*.js(*是个随机数)步骤一 资源引入vue最外层index.html文件引入资源文<body&gtl;     <di...
Vue 如何返回上一页(上一个锚点)//...省略 methods:{ goback:function(){ this.$router.go(-1);//...
vue
在初始化完一个vue项目(基于vue-cli 和webpack)之后,我们可以通过 npm run dev来让这个项目跑起来
vue watch监控对象属性变化watch:{ 'object.attr':function attr(value){ //处理操作 } ...
一、前言Vue 2.x 使用期间,我们会创建众多组件,这里我们将讨论一下各个组件直接的相互通讯问题如何解决
一、如何在vue中使用route跳转页面并传递参数this.$router.push({ path: '/path/to/your',query:{param1:value1,param2:va...
先说两句官方已经有教程了,为什么还要写这个教程呢?说实话,还真不是我闲着蛋疼,官方的教程真的是太官方了,对于刚入门 Vuex 的童鞋来说,想必看官方的教程
一、vue-router路由跳转分为两大类编程式的跳转:router.push声明式的跳转:<router-link&gtl;二、编程式的跳转分为三种1、this.$router.push...
一.vue ref基本用法:本页面获取dom元素$title(t1.vue) <template&gtl; <div id="app"&gtl; <div r...
先安装nodejs然后全局安装pnpm工具npm install -g pnpm