Vue重置当前页面的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.optionsvm.options,vm.options.data()中的this指向vm.optionsmethodABvm.options,而methodA和B并没有直接挂在vm.options下,所以this.methodA和this.B为undefined。

参考链接

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章