Vue中恢复数据为初始状态

Vue中恢复数据为初始状态

在 Vue 项目开发过程中,遇到需要重新使用 data 中的数据,但是data中的数据已经被赋值改变了,如何重置data的值为初始状态呢?

解决办法:

1. 直接赋值(不建议使用,若有多个地方需要重新设置数据,产生大量重复冗余的代码)

this.form = { 需要设置的数据 }
复制代码

2. 使用this.$options.data()获取初始 data 的值,再使用Object.assign()来复制对象;

this.$data:获取当前状态下的 data,也就是要改变的 data 数据; this.$options.data(): vue原始的数据,就是你页面刚加载时的 data

Object.assign(this.$data, this.$options.data())
复制代码

若需要给某一个具体的数据 (eg: form) 重新设置值,则使用如下的方法,eg:

Object.assign(this.$data.form, this.$options.data().form)
复制代码

3. 使用全局变量

注意!

data()中若使用了 this 来访问 props 或 methods,用 this.$options.data() 重置组件data时,data()里用 this 获取的 props 或 method 都为 undefined,注意 this.$options.data() 的 this 指向,最好使用 this.$options.data.call(this)。

  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
解决方案如下:当在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 ]
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值