JavaScript基础教程之如何用 JavaScript一次获取 HTML 表单的所有字段
小职 2020-10-12 来源 : 阅读 611 评论 0

摘要:JavaScript的应用:本篇介绍了用 JavaScript一次获取 HTML 表单的所有字段,希望对JavaScript的学习有更深入的了解。

JavaScript的应用:本篇介绍了用 JavaScript一次获取 HTML 表单的所有字段,希望对JavaScript的学习有更深入的了解。

JavaScript基础教程之如何用 JavaScript一次获取 HTML 表单的所有字段

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

 

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

 

<form>

   <label for="name">用户名</label>

   <input type="text" id="name" name="name" required>

   <label for="description">简介</label>

   <input type="text" id="description" name="description" required>

   <label for="task">任务</label>

   <textarea id="task" name="task" required></textarea>

   <button type="submit">提交</button>

 </form>

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

 

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

 

从事件 target 获取表单字段

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

 

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

 

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

 

使用 FormData

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

 

const form = document.forms[0];

form.addEventListener("submit", function(event) {

  event.preventDefault();  const formData = new FormData(this);

});

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

 

const form = document.forms[0];

form.addEventListener("submit", function(event) {

  event.preventDefault();  const formData = new FormData(this);

  for (const formElement of formData) {

    console.log(formElement);

  }})

 

 

 

 

 

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

 

const form = document.forms[0];

form.addEventListener("submit", function(event) {

  event.preventDefault();  const formData = new FormData(this);

  const entries = formData.entries();

  const data = Object.fromEntries(entries);

});

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

 

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

 

const form = document.forms[0];

form.addEventListener("submit", function(event) {

  event.preventDefault();  const formData = new FormData(this);

  const entries = formData.entries();

  const data = Object.fromEntries(entries);

  // send out to a REST API

  fetch("https://some.endpoint.dev", {

    method: "POST",

    body: JSON.stringify(data),

    headers: {

      "Content-Type": "application/json"

    }

  })

    .then(/**/)

    .catch(/**/);

});

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

 

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

 

总结

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

 

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

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



关注“职坐标在线”公众号,免费获取最新技术干货教程资源哦!



本文由 @小职 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程