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

vuex在页面刷新后数据被清除

用vuex来做全局的状态管理, 发现当刷新网页后,保存在vuex实例store里的数据会丢失 产生原因 其实很简单,因为store里的数据是保存在运行内存中的,当页面刷新时,页面会重新加载vue实例,store...而第二种可以保证刷新页面数据不丢失且易于读取。...又由于vuex规定所有state里数据必须通过mutation方法来修改,所以第一种方案就是mutation修改state的同时修改sessionStorage对应存储的属性 第二种方案 第一种方案确实可以解决问题...因为我们是只有在刷新页面时才会丢失state里的数据,想法在点击页面刷新时先将state数据保存到sessionStorage,然后才真正刷新页面 beforeunload这个事件在页面刷新时先触发的。...我们总不能每个页面都监听这个事件,所以选择放在app.vue这个入口组件中,这样就可以保证每次刷新页面都可以触发。

3.1K00
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Vue路由嵌套刷新后页面没有重新渲染

    Vue路由嵌套刷新后页面没有重新渲染 强烈推介IDEA2020.2破解激活,IntelliJ...IDEA 注册码,2020.2 IDEA 激活码 问题 在路由嵌套时,如果此时地址栏到了子路由下面,刷新页面路由地址肯定不会有变化,那么此时会出现子路由页面没有重新渲染的情况。...让它显示出来,在父路由重新渲染完成后,将条件渲染的值变为false,在修改渲染条件数据之后使用 $nextTick,再将条件渲染的值变为true,相当于重新加载了一次子路由。...}); } 方法2 其实上述方法的原理就是让浏览器认为是一个新的子路由,所以对其进行重新加载渲染,同理,另一种方法是给容器router-view一个key值即可完美解决,每次刷新的随机值都让容器看上去是一个新的

    1.5K30

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

    所以,意味着用户进入页面或者刷新页面,这个值就会变成我自己设定的100000.那么第一个限制条件就完成了。...这样,如果这两个条件同时成立,那就能断定他是刷新了。 那么这个状态值需要在一开始没有,页面初始化后才存在,且页面刷新不丢失。 什么数据这么神通广大?!那就是sessionstorage设置的数据。...TeamID缩写,需要保留的重要信息 然后开始判断条件是否同时成立: 但是这里有一点,需要利用js的同步逻辑,这段判断的代码要提前放到最顶部,即初始化数据没有设定之前: 因为如果数据设定以后,每次初始化进入页面后...,这时应该清除或者重置一下,不然页面一进来数据还存在,这里条件就会成立,会变成死循环,展示上就是页面一直跳转一直刷新。...TeamID=' + newTeamID; } } 这样解决了刷新后页面空白的问题,重定向重新请求数据 但是如果为了解决部分数据丢失的问题,也可以直接将数据实现存在sessionstorage内

    3K20

    2025最新出炉--前端面试题九

    手动触发更新(setState)。 组件通信 props/emit、Provide/Inject。 props、Context、状态管理库。...适用场景 模板中需要动态计算的属性。 数据变化后需要执行非纯操作(如日志记录)。...新增/删除属性 支持直接监听。 需手动调用 Vue.set/Vue.delete。 数组索引修改 直接监听。 需重写数组方法(如 push)。 性能 惰性代理(仅在访问时触发)。...能讲讲 vuex 吗, 刷新页面会怎样 回答: Vuex 是 Vue 的状态管理库,核心概念: State:单一状态树,存储全局数据。...刷新页面问题: Vuex 的状态存储在内存中,页面刷新后状态丢失。 解决方案: 持久化插件:如 vuex-persistedstate,将状态保存到 localStorage。

    3400

    vue学习:使用tab标签页时,刷新页面停留在当前tab

    现状:无论当前停留在哪个标签,刷新页面都会回到默认设定的标签 原始代码如下 v-model="activeName" @...="activeName",它和选项卡中的 name属性进行绑定; 而在 data() 中设置了activeName: 'first',所以首次打开这个页面或者刷新页面后,都会定位到第一个标签 现在想实现这样一个效果...:当处于某个标签时,刷新页面会停留在当前标签 思路:当点击某个标签时,获取到当前 name 的值,然后刷新页面时把name的值赋给activeName,这样每次刷新后activeName总能拿到上次的标签...activeName更新为当前标签的name属性值 添加一个钩子函数 created(),从缓存中拿到 current_name ,并把它赋给activeName methods: { handleClick...,确实会停留在当前标签,切换标签后刷新,也能达到这个效果 但是如果是首次进入系统,直接点击【创建随机数据】这个菜单,会发现没有自动打开任何一个标签,因为刷新页面后是获取缓存中的name,而此时标签name

    3.5K30
    领券