vue如何重置data的所有属性
重置data的所有属性
1.拿到data原始属性
this.$options.data()
2.拿到当前的data
this.$data
3.复制到当前$data里面
Object.assign(this.$data, this.$options.data());
重置当前页面的data
问题一
在某些情况下,需要重新使用data中的数据,但是data中的数据已经被各种表单、变量等赋值,那么怎么重置data的值呢?
解决方式:Object.assign()
JS相关函数
函数 | 含义 |
---|---|
Object.assign(target, …sources) | 将所有可枚举属性值从一个或多个源对象复制到目标对象 |
vue中相关函数
函数 | 含义 |
---|---|
this.$data | 当前状态下的data |
this.$options.data() | 该组件初始状态下的data |
所以,可以通过下面的方式重置当前页面的data:
Object.assign(this.$data, this.$options.data.call(this));
或者,单独重置data中的某一个对象或者属性:
this.form = this.$options.data().form
问题二
用 this.$options.data() 重置组件data时,data() 里用this获取的props或methods都为undefined
原因
new Vue的时候传了一个对象,把该对象记为options,Vue将options中自定义的属性和Vue构造函数中定义的属性合并为vm.options,vm.options.data()中的this指向vm.options ,而methodA和B并没有直接挂在vm.options下,所以this.methodA和this.B为undefined。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Vue-router结合transition实现app前进后退动画切换效果的实例
下面小编就为大家带来一篇Vue-router结合transition实现app前进后退动画切换效果的实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-10-10vue3使用threejs实现3D卡片水平旋转效果的示例代码
这篇文章主要介绍了在vue3中使用threejs实现3D卡片水平旋转效果,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下2024-04-04vite项目的根目录中的env.d.ts类型声明文件里要写什么
这篇文章主要介绍了vite项目的根目录中的env.d.ts类型声明文件里要写什么,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-08-08利用Vite搭建Vue3+ElementUI-Plus项目的全过程
vue3如今已经成为默认版本了,相信大多数公司已经全面拥抱vue3了,下面这篇文章主要给大家介绍了关于利用Vite搭建Vue3+ElementUI-Plus项目的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2022-07-07
最新评论