余晖落尽暮晚霞,黄昏迟暮远山寻
本站
当前位置:网站首页 > 编程知识 > 正文

vue.js使用小技巧(vue怎么使用js)

xiyangw 2022-11-26 15:52 21 浏览 0 评论

背景

我们在写vue2项目时,经常会遇到需要重置数据的场景,例如有这样一个组件:

data() {
	return {
  	title: '',
    subTitle: '',
    author: '',
    content: ''
  }
},
methods: {
  // 调提交数据接口
	submit() {
  	http.post('xxxx', {
    	// 要提交的一些数据。。。
      title: this.title,
      subTitle: this.subTitle,
      author: this.author,
      content: this.content
    }).then(res => {
    	// 提交成功
      // 清空数据
      this.title = ''
      this.subTitle = ''
      this.author = ''
      this.content = ''
    })
  }
}

以上代码不仅看着不够优雅,写起来也是相当麻烦,字段少还可以这么写,那要是几十个甚至更多的字段呢?

vue.js使用小技巧(vue怎么使用js)

有人说可以用一个对象把需要重置的字段包起来,像下面这样:

data() {
	return {
  	formData: {
    	title: '',
      subTitle: '',
      author: '',
      content: ''
    }
  }
},
methods: {
  // 调提交数据接口
	submit() {
  	http.post('xxxx', {
    	// 要提交的一些数据。。。
      ...this.formData
    }).then(res => {
    	// 提交成功
      // 清空数据
      this.formData = {
      	title: '',
        subTitle: '',
        author: '',
        content: ''
      }
    })
  }
}

看上去好像是优雅一点了,少了几行代码,但也是换汤不换药。那么有没有一种方法可以一行代码重置呢?

答案是:当然有。

我们都知道尤大发布了vue3,与vue2最大的不同就是,vue2被称为选项式(Option)api,vue3被称为组合式(Composition)api。

在vue2中,我们可以通过this关键字来访问当前vue实例的属性和方法,其中有一个特殊的属性,$options

$options的值是个对象{},打印它可以看到内部有一个data(){}函数,也就是我们在组件中声明的data函数,这个函数返回了一些我们自己定义的字段。

那么我们就可以再次调用data这个函数,不就可以拿到初始值了吗?

搜索引擎搜索:“vue2重置数据”。基本上可以得到两种答案:

// 第一种
this.formData = this.$options.data().formData
// 第二种
Object.assign(this.formData, this.$options.data().formData)
// 当然也可以使用
Object.assign(this.$data, this.$options.data())

解释

以上代码解释

vue中:

this.$data 获取当前状态下的data

this.$options.data() 获取该组件初始状态下的data

区别

那么以上两种方法有什么区别呢?

乍一看没区别,运行起来也没区别,实际上在某种场景下是有区别的。

查看MDN,Object.assign(target, ...sources) 方法可以合并两个对象,会改变target本身,如果两个对象中有相同的属性,后面的会覆盖前面的。而且如果后面的对象里新增了一些属性,也会被合并到目标对象。但是第一种方法就不会,而是会完全重置到data最初始的状态,这就是二者的区别。具体使用哪一种还是要看具体场景。

相关推荐

spring利用spring.handlers解析自定义配置(spring validation 自定义)

一、问题我们在spring的xml配置文件里经常定义各种各样的配置(tx、bean、mvc、bean等等)。以及集成第三方框架时,也会看到一些spring之外的配置,例如dubbo的配置、securi...

「Spring源码分析」AOP源码解析(上篇)(spring源码深度解析(第2版))

前言前面写了六篇文章详细地分析了SpringBean加载流程,这部分完了之后就要进入一个比较困难的部分了,就是AOP的实现原理分析。为了探究AOP实现原理,首先定义几个类,一个Dao接口:1&nbs...

Spring 解析注册BeanDefinition这一篇就Over
Spring 解析注册BeanDefinition这一篇就Over

一、简介:学习过Spring框架的人一定都会听过Spring的IoC(控制反转)、DI(依赖注入)这两个概念,对于初学Spring的人来说,总觉得IoC、...

2023-03-20 14:53 xiyangw

域、模块、空间、闭包,你真的懂了吗?(模块控制域与作用域的关系)

Javascript有一个特性叫做域。尽管对于初学者来说理解域是有难度的,但我会尽力用最简单的方式让你理解域。理解域能让你的代码更优秀,减少错误,及有助于你做出更强大的模式设计。什么是域域是在运行时,...

这一次搞懂Spring自定义标签以及注解解析原理
这一次搞懂Spring自定义标签以及注解解析原理

前言在上一篇文章中分析了Spring是如何解析默认标签的,并封装为BeanDefinition注册到缓存中,这一篇就来看看对于像context这种自定义标签是如...

2023-03-20 14:53 xiyangw

前端基础进阶(七)-前端工程师最容易出错的问题-this关键字
前端基础进阶(七)-前端工程师最容易出错的问题-this关键字

我们在学习JavaScript的时候,因为对一些概念不是很清楚,但是又会通过一些简洁的方式把它给记下来,那么这样自己记下来的概念和真正的概念产生了很强的偏差.当...

2023-03-20 14:52 xiyangw

深入K8s:守护进程DaemonSet及其源码分析(k8s 进程)
深入K8s:守护进程DaemonSet及其源码分析(k8s 进程)

建议学习:膜拜!阿里内部都在强推的K8S(kubernetes)学习指南,不能再详细了最近也一直在加班,处理项目中的事情,发现问题越多越是感觉自己的能力不足,...

2023-03-20 14:52 xiyangw

Spring 是如何解析 bean 标签的?(spring beans标签)
Spring 是如何解析 bean 标签的?(spring beans标签)

前情回顾上回「SpringIoC容器初始化(2)」说到了Spring如何解析我们定义的<bean>标签,代码跟进了一层又一层,跋山涉水,...

2023-03-20 14:52 xiyangw

快速了解JavaScript文本框操作(javascript文本框代码)
快速了解JavaScript文本框操作(javascript文本框代码)

HTML中使用<input>元素表示单行输入框和<textarea>元素表示多行文本框。HTML中使用的<input&...

2023-03-20 14:51 xiyangw

荐读|30道JavaOOP面试题,可以和面试官扯皮了
荐读|30道JavaOOP面试题,可以和面试官扯皮了

面试是我们每个人都要经历的事情,大部分人且不止一次,今天给大家准备了30道JavaOOP面试题,希望能够帮助到对Java感兴趣的同学,让大家在找工作的时候能够...

2023-03-20 14:51 xiyangw

源码系列——mybatis源码刨析总结,下(mybatis源码分析)
源码系列——mybatis源码刨析总结,下(mybatis源码分析)

接上文简答题一.1.Mybatis动态sql是做什么的?1.动态sql就是根据条件标签动态的拼接sql,包括判空,循环,拼接等2.哪些动态sql?动态sql大...

2023-03-20 14:50 xiyangw

Java面试题(第二弹)(java面试题及答案整理)
Java面试题(第二弹)(java面试题及答案整理)

1.抽象类和接口的区别?接口可以被多重implements,抽象类只能被单一extends接口只有定义,抽象类可以有定义和实现接口的字段定义默认为:public...

2023-03-20 14:50 xiyangw

mybatis3 源码深度解析-动态 sql 实现原理(sql数据库基础知识)
mybatis3 源码深度解析-动态 sql 实现原理(sql数据库基础知识)

大纲动态sql使用示例SqlSource和BoundSql以及实现类LanguageDriver以及实现类SqlNode以及实现类动态sql解...

2023-03-20 14:50 xiyangw

第43节 Text、Comment及CDATASection(第43节 Text、Comment及CDATASection)
第43节 Text、Comment及CDATASection(第43节 Text、Comment及CDATASection)

本内容是《Web前端开发之Javascript视频》的课件,请配合大师哥《Javascript》视频课程学习。文本节点用Text类型表示,包含的是可以按字面解释...

2023-03-20 14:49 xiyangw

Qt读写三种文件(qt读取文件数据并赋值给变量)

第一种INI配置文件.ini文件是InitializationFile的缩写,即初始化文件。除了windows现在很多其他操作系统下面的应用软件也有.ini文件,用来配置应用软件以实现不同用户的要...

取消回复欢迎 发表评论: