首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Vuex页面刷新数据丢失问题

Vuex页面刷新数据丢失问题 1、问题描述 2、解决方案:使用sessionStorage   在实际项目中,经常会遇到多个组件需要访问同一个数据的情况,且都需要根据数据的变化作出响应,而这些组件之间可能并不是父子组件这种简单的关系...1、问题描述 Vuex用起来确实很舒服,但是今天碰到了个问题,就是我将JWT和一些权限字符串使用store保存的时候,刷新页面之后这些值就没了,由于我后端集成了SpringSecurity,所以每次请求我都会去验证...JWT,如果刷新页面的话,后续请求头中就没有token,就会导致报错。   ...state.token = token } }, actions: { }, modules: { } })   刚登录进去还是有值的,如下图:   刷新页面之后...actions: { }, modules: {} }) 这里为了直观,我只留下token和menuList两个state   重新登录查看Vuex中的state 此时再刷新页面

1.6K30

vue传参页面刷新数据丢失问题

在做vue的时候,经常会遇到组件之间数据的传递问题,通过params或者query传参,但是,当页面刷新的时候,数据丢失,找不到数据。今天经过总结,解决了这个问题。...通过了一下几种情况进行传值: 通过路由params传参 通过路由query传参 通过vuex 1.通过params传参 先在路由path里那个组件需要传递参数,定义一个参数,用于组件传递,params刷新页面数据丢失...1.通过query传参 路由传值有两种方式,params和query,params传值刷新页面是要消失的,然而query却不会,两者的区别就在于query会把传递的参数显示在url地址中,就像下面这样...这样无论怎么刷新数据都不会丢失。 3.通过vuex取  最好办的就是通过vuex来存和取你的数据,把你的数据都存在vuex中,然后那个组件需要,直接调用vuex的getters来获取数据就行。...以上是路由传参和vuex存值、传值的时候刷新页面数据消失的解决办法。喜欢的可以关注一下。

2.8K20
您找到你想要的搜索结果了吗?
是的
没有找到

Vuex数据页面刷新丢失问题解决方案

用Vue做项目开发很久了,对于vuex能用、会用,但是因为状态脱离页面刷新丢失两个原因,一直都有种抵触,特别是一些简单的数据都是通过query或者本地存储就解决了,然而对于一些复杂内容,不可避免的还是要使用...Vuex去处理(真香),但是刷新丢失的问题,的确叫人头大。...最近闲下来,我们来研究下怎么干掉这个问题~ 不大了解Vuex的同学,可以先去官网溜溜 由于Vuex的数据是存储在内存中的,相当于memory cache,当页面刷新的时候内存被清空重载新内容,原来的数据就丢了...const storeMaker = (state) => { // 初始化 Object.keys(state).map((key) => { // 判断类型获取本地存储数据...userLevel } }, modules: { } }) 内容不多,主要定义了一个storeMaker的函数实现了两个功能 1、对传入的state初始值判断类型,尝试从

2.7K30

vuex + sessionstorage 解决vue项目刷新页面空白数据丢失

soeasy,思考一个问题,为什么sessionstorage刷新页面不会清空数据呢?...这样,如果这两个条件同时成立,那就能断定他是刷新了。 那么这个状态值需要在一开始没有,页面初始化后才存在,且页面刷新丢失。 什么数据这么神通广大?!那就是sessionstorage设置的数据。...,这时应该清除或者重置一下,不然页面一进来数据还存在,这里条件就会成立,会变成死循环,展示上就是页面一直跳转一直刷新。...而在判断的下边,调用ajax获取数据,并把响应结果中的关键信息(本案例中的newTeamID)一寄托给sessionStorage: $axios.get(state.ownSet.dataUrl +...TeamID=' + newTeamID; } } 这样解决了刷新页面空白的问题,重定向重新请求数据 但是如果为了解决部分数据丢失的问题,也可以直接将数据实现存在sessionstorage内

2.9K20

·html实现返回页面自动刷新

[开发技巧]·html实现返回页面自动刷新 个人网站–> http://www.yansongsong.cn 问题描述 在进行APP开发或作制作网站时,有时候会遇到你下一级页面操作过以后会改变上一级页面的结果...这时候就需要我们去刷新上一级页面。...一般可以采取三种方式: 定时刷新 用eventListener,检测事件 使用execScript,外部执行js 我选用的是第三个方式,操作简单,效率高,且代码量少。...script: jsFun }); } 执行,在b_frame.html计算出结果,需要返回a.html时,调用: winReload("a", "a_frame"); 因为我的数据是放在服务器端...,当执行location.reload()就会自动从服务器端获取更新,如果你的数据存放在本地,可以使用参数传递,或者setStorge()方法。

6K30

vue-router 路由传参,刷新页面参数丢失

常见场景:点击列表的详情,跳转到详情内页,在内页根据传递的参数获取详情数据。 ?...name,路径用 name,路径用 name , 用 path 会获取不到;如果在路由配置中没有添加 /:id 即 path: ‘detail’,url 中不会显示 id,在详情页还是可以拿到参数 id,但刷新后参数丢失...$route.query.obj) 这个方法虽然可以传递对象,若数据少还好,数据多的话地址栏就很长了 注意:在所有的子组件中获取路由参数是 route 不是 router 以上 params 和 query...传参方式对比: 通过 $router.push 的 params + name 传参,若路由中没有设置params参数,参数不会拼接在路由后面,但是页面刷新参数会丢失。...console.log(this.id) } } 详见:动态路由匹配 路由组件传参 此外,还可以通过把参数存在 sessionStorage 或 localStorage 中来解决页面刷新参数丢失的问题

4.3K10

vue路由传参页面刷新参数丢失问题解决方案

最近项目中涉及到跨页面传参数和后台进行数据交互,看到需求之后第一反应就是用路由传参来解决;Vue中给我们提供了三种路由传参方式,下面我们一个一个的来看一下: 方法一:params传参: this....$router.push({ name:"admin",     //这里的params是一个对象,id是属性名,item.id是值(可以从当前组件或者Vue实例上直接取) params...,就是当页面刷新了是获取不到参数值的,那么有没有一种方法是页面刷新之后参数依然存在呢?...',   //组件别名 name: 'admin',   //组件名 component: Admin, } 第三种方式是用query来传参,这种方式是可以解决页面刷新参数消失问题的,这种方式可以理解为是...ajax中的get方法,参数是直接在url后面添加的,参数是可见的,所以解决页面刷新参数消失问题建议使用方法三来解决; 其实解决页面刷新参数丢失问题的方案还有很多,比如把参数存在sessionStorange

3K30

vue监听页面刷新事件_vue监听数据变化自动刷新

onload、onunload、onbeforeunload的执行问题: 页面加载时只执行onload 页面关闭时,先onbeforeunload事件,再onunload...页面刷新时先执行onbeforeunload,然后onunload,最后onload。 注意:这种执行顺序是有浏览器的兼容问题的,请注意各种浏览器的区别。...onbeforeunload() 和onunload() 两个事件的区别: 相同点: 两者都是在对页面的关闭或刷新事件作个操作。...(因为,onbeforeunload()是在页面刷新之前触发的事件,而onubload()是在页面关闭之后才会触发的)。...---- vue中监听页面刷新和离开 方法一:直接在mounted或者activated中写 mounted() { //写在mounted或者activated生命周期内即可 window.onbeforeunload

5.6K20

vuex在页面刷新数据被清除

用vuex来做全局的状态管理, 发现当刷新网页后,保存在vuex实例store里的数据丢失 产生原因 其实很简单,因为store里的数据是保存在运行内存中的,当页面刷新时,页面会重新加载vue实例,store...而第二种可以保证刷新页面数据丢失且易于读取。...vue是单页面应用,操作都是在一个页面跳转路由;sessionStorage可保证打开页面时sessionStorage的数据为空,而如果是localStorage则会读取上一次打开页面数据。...因为我们是只有在刷新页面时才会丢失state里的数据,想法在点击页面刷新时先将state数据保存到sessionStorage,然后才真正刷新页面 beforeunload这个事件在页面刷新时先触发的。...我们总不能每个页面都监听这个事件,所以选择放在app.vue这个入口组件中,这样就可以保证每次刷新页面都可以触发。

3K00

离开页面前,如何防止表单数据丢失

用户常见的一个烦恼来源是由于意外离开页面丢失未保存的更改。 本文将演示如何实现一个 FormPrompt 组件,当用户尝试离开具有未保存更改的页面时,会发出警报,从而有效地提高整体用户体验。...Field> Next {">"} ); }); 当在表单字段中输入数据并在保存更改之前尝试重新加载页面或导航到外部...,输入的数据不会被保存,也不会出现任何确认对话框。...使用 Prompt 时,导航到主页路由时行为正确,但是当用户输入表单数据并进入下一步时,确认对话框也会出现。这是不希望的,因为我们在导航到下一步时保存表单数据。...最后,我们在 usePrompt 钩子中抽象出阻止逻辑管理阻止器的状态。 我们可以通过导航到联系步骤,填写一些字段单击主页导航项来测试 FormPrompt 是否按预期工作。

5.8K20
领券