vue pinia跨页读取数据到旧数据问题

近日做一个前端项目用的是vue3 ,状态管理用的是pinia,在 保存数据,在同一窗口打开新页面,数据读取正常,当用window.open(url)打开新页面时,读到的数据就不是新保存的数据,查了很多资料都没有解决。后来静下心来看pinia-plugin-persistedstate官方文档,才在文档中找到答案。

Forcing the persistence

In case you need to manually trigger persistence to storage, every store now exposes a $persist method.

Given this store:

ts

import { defineStore } from 'pinia'

const useStore = defineStore('store', {
  state: () => ({
    someData: 'Hello Pinia'
  })
})

You can call $persist:

ts

const store = useStore()

store.$persist()

 如上所示,store.$persist()可以强制持久化,保存state,在原来的保存文句后面调用store.$persist(),强制保存后,用window.open(url)打开新页面时,在新页面读到的数据就是最新的数据了,可见pinia的持久化是有延迟的。

  that.setArticle(article);

                   that.store.$persist();

  • 9
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
解决方案如下:当在Vue项目中使用pinia进行状态管理时,刷新页面会导致pinia中的数据丢失。一个解决方法是在刷新页面之前先将数据存储到localStorage中,然后在初始化pinia时,将存储在localStorage中的数据读取出来重新赋值给pinia的状态。具体的实现步骤如下: 1. 在pinia的mutations中,在修改状态的同时,使用`window.localStorage.setItem`方法将数据存储到localStorage中。例如: ```javascript orderList(s, d) { s.orderList = d; window.localStorage.setItem("orderList", JSON.stringify(s.orderList)); }, ``` 2. 在初始化pinia时,可以在store的构造函数中读取localStorage中的数据,并重新赋值给pinia的状态。例如: ```javascript import { createStore } from 'pinia'; export const useStore = createStore({ state: () => ({ orderList: JSON.parse(window.localStorage.getItem("orderList")) || [], menuList: JSON.parse(window.localStorage.getItem("menuList")) || [], }), ... }); ``` 这样,在刷新页面之后,pinia的状态就可以从localStorage中恢复,并且数据不会丢失了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [解决VUE页面刷新,数据丢失「建议收藏」](https://blog.csdn.net/cddcj/article/details/126251117)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [vite+vue3+pinia+vuex4动态路由解决刷新页面丢失](https://blog.csdn.net/z3133464733/article/details/130119492)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值