iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue如何重置data的所有属性
  • 547
分享到

vue如何重置data的所有属性

2024-04-02 19:04:59 547人浏览 安东尼
摘要

目录重置data的所有属性1.拿到data原始属性2.拿到当前的data3.复制到当前$data里面重置当前页面的data问题一问题二重置data的所有属性 1.拿到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。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。 

--结束END--

本文标题: vue如何重置data的所有属性

本文链接: https://www.lsjlt.com/news/146347.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作