vue有没有像微信小程序那样可修改的全局变量

vue有没有像微信小程序那样可修改的全局变量

我想在vue中使用一个全局变量来存储数据,在全局都可以使用的,也可以修改,就类似微信小程序的那样。

1、我用过Vue.prototype.$http这个,但是这个不可以在其他页面修改

2、也用过store,这个在A页面修改完数据,跳转到B页面后,在created中可以获取,但是在B页面刷新一下,created就显示store里面的数据为空了

3、也试过了这种

export default {
    examId: '',
    setExamId(id) {
        this.examId = id;
    }
}

但是这样也遇到了和2中一样的情况

没有哪位大佬知道可以实现的方法?

阅读 2.7k
5 个回答

怎么不使用localStorage呢

小程序不也一样刷新一下就没了吗,也一样要在初始化的时候取缓存赋值给全局变量啊

单页面应用刷新自然会清除相关的设置,因为所有的数据都存在js里面,当刷新之后js重新获取以前的修改就丢失了。
既然localStorage你觉得安全性不高又想要保存更改,我觉得只能使用请求根据用户的id来设置和获取了。安全性高甚至你换台设备都知道你原来的修改。

这个可以考虑session存储,或者说在服务器端存储。
但真正的其实还是推荐本地存储,即localStorage。
你所说的localStorage可以在客户端修改问题其实是一个伪问题,如果你这个存储值要防修改(只是是服务器端返回情况写入),可以在服务器端进行一些加密,再加上校验存储,这样客户端修改了就不匹配,需要重新处理啦。

而且这样的情况其实不限于vue,其实所有要实现刷新后状态保持,都需要本地存储的再加载与解析。

此外可以考虑vuex或者类似的机制。

不过本质来说vuex还是本地存储,只是和vue搭配可能更方便,也解决不了你不在客户端存储数据(担心泄密)这样的需求。

2刷新没有数据是不是没有vuex持久化呢

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题