如何用 JS 一次获取 HTML 表单的所有字段 ?

开发 前端
有两种方法:一种是用黑科技,另一种是更清洁,也是最常用的方法。为了演示这种方法,我们先创建form.js,并引入文件中。

 [[345257]]

问:如何用 JS 一次获取 HTML 表单的所有字段 ?

考虑一个简单的 HTML 表单,用于将任务保存在待办事项列表中:

  1. <form> 
  2.    <label for="name">用户名</label> 
  3.    <input type="text" id="name" name="name" required> 
  4.  
  5.    <label for="description">简介</label> 
  6.    <input type="text" id="description" name="description" required> 
  7.  
  8.    <label for="task">任务</label> 
  9.    <textarea id="task" name="task" required></textarea> 
  10.  
  11.    <button type="submit">提交</button> 
  12.  </form> 

上面每个字段都有对应的的type,ID和 name属性,以及相关联的label。用户单击“提交”按钮后,我们如何从此表单中获取所有数据?

有两种方法:一种是用黑科技,另一种是更清洁,也是最常用的方法。为了演示这种方法,我们先创建form.js,并引入文件中。

从事件 target 获取表单字段

首先,我们在表单上为Submit事件注册一个事件侦听器,以停止默认行为(它们将数据发送到后端)。

然后,使用this.elements或event.target.elements访问表单字段:

相反,如果需要响应某些用户交互而动态添加更多字段,那么我们需要使用FormData。

使用 FormData

首先,我们在表单上为submit事件注册一个事件侦听器,以停止默认行为。接着,我们从表单构建一个FormData对象:

  1. const form = document.forms[0]; 
  2.  
  3. form.addEventListener("submit"function(event) { 
  4.   event.preventDefault(); 
  5.   const formData = new FormData(this); 
  6. }); 

除了append()、delete()、get()、set()之外,FormData 还实现了Symbol.iterator。这意味着它可以用for...of 遍历:

  1. const form = document.forms[0]; 
  2.  
  3. form.addEventListener("submit"function(event) { 
  4.   event.preventDefault(); 
  5.   const formData = new FormData(this); 
  6.  
  7.   for (const formElement of formData) { 
  8.     console.log(formElement); 
  9.   } 
  10. }) 

除了上述方法之外,entries()方法获取表单对象形式:

  1. const form = document.forms[0]; 
  2.  
  3. form.addEventListener("submit"function(event) { 
  4.   event.preventDefault(); 
  5.   const formData = new FormData(this); 
  6.   const entries = formData.entries(); 
  7.   const data = Object.fromEntries(entries); 
  8. }); 

这也适合Object.fromEntries() (ECMAScript 2019)

为什么这有用?如下所示:

  1. const form = document.forms[0]; 
  2.  
  3. form.addEventListener("submit"function(event) { 
  4.   event.preventDefault(); 
  5.   const formData = new FormData(this); 
  6.   const entries = formData.entries(); 
  7.   const data = Object.fromEntries(entries); 
  8.  
  9.   // send out to a REST API 
  10.   fetch("https://some.endpoint.dev", { 
  11.     method: "POST"
  12.     body: JSON.stringify(data), 
  13.     headers: { 
  14.       "Content-Type""application/json" 
  15.     } 
  16.   }) 
  17.     .then(/**/) 
  18.     .catch(/**/); 
  19. }); 

一旦有了对象,就可以使用fetch发送有效负载。

小心:如果在表单字段上省略name属性,那么在FormData对象中刚没有生成。

总结

要从HTML表单中获取所有字段,可以使用:

this.elements或event.target.elements,只有在预先知道所有字段并且它们保持稳定的情况下,才能使用。

使用FormData构建具有所有字段的对象,之后可以转换,更新或将其发送到远程API。

作者:VALENTINO GAGLIARDI  译者:前端小智  来源:valentinog

原文:https://www.valentinog.com/blog/form-data/

本文转载自微信公众号「CSS特效世界」,可以通过以下二维码关注。转载本文请联系CSS特效世界公众号。

 

责任编辑:武晓燕 来源: CSS特效世界
相关推荐

2020-10-10 08:49:02

JS

2021-11-26 14:45:16

日志Java代码

2022-11-18 08:31:56

Spring日志工具

2011-06-28 10:41:50

DBA

2023-12-04 19:15:00

连接池case

2020-03-19 15:32:47

手机消毒病毒

2020-10-24 13:50:59

Python编程语言

2021-12-27 10:08:16

Python编程语言

2018-03-27 18:12:12

PythonHTML

2019-04-18 10:55:00

故障演练流量

2023-01-04 10:49:01

ml5.jsHTML工具

2016-09-27 19:28:37

2021-05-31 10:23:10

恶意软件攻击网络安全

2011-04-07 11:20:21

SQLServer

2012-08-28 09:21:59

Ajax查错经历Web

2021-11-01 17:29:02

Windows系统Fork

2009-06-08 09:39:46

2010-09-07 11:09:33

SQL语句

2022-04-14 20:43:24

JavaScript原型链

2014-07-17 15:31:48

点赞
收藏

51CTO技术栈公众号