这篇“Vue怎么重置data的所有属性”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue怎么重置data的所有属性”文章吧
这篇“Vue怎么重置data的所有属性”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue怎么重置data的所有属性”文章吧。
this.$options.data()
this.$data
Object.assign(this.$data, this.$options.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怎么重置data的所有属性”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。
--结束END--
本文标题: vue怎么重置data的所有属性
本文链接: https://lsjlt.com/news/327434.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0