如何用 JS 一次获取 HTML 表单的全部字段 ?

做者:VALENTINO GAGLIARDI
译者:前端小智
来源:valentinog
移动端阅读: https://mp.weixin.qq.com/s/rj...

点赞再看,养成习惯

本文 GitHub https://github.com/qq44924588... 上已经收录,更多往期高赞文章的分类,也整理了不少个人文档,和教程资料。欢迎Star和完善,你们面试能够参照考点复习,但愿咱们一块儿有点东西。前端


问:如何用 JS 一次获取 HTML 表单的全部字段 ?git

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

<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>

上面每一个字段都有对应的的typeIDname属性,以及相关联的label。 用户单击“提交”按钮后,咱们如何今后表单中获取全部数据?面试

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

从事件 target 获取表单字段

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

而后,使用this.elementsevent.target.elements访问表单字段:app

相反,若是须要响应某些用户交互而动态添加更多字段,那么咱们须要使用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 遍历:fetch

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);
  }
})

clipboard.png

clipboard.png

除了上述方法以外,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.elementsevent.target.elements,只有在预先知道全部字段而且它们保持稳定的状况下,才能使用。

使用FormData构建具备全部字段的对象,以后能够转换,更新或将其发送到远程API。*


原文:https://www.valentinog.com/bl...

代码部署后可能存在的BUG无法实时知道,过后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给你们推荐一个好用的BUG监控工具 Fundebug


交流

干货系列文章汇总以下,以为不错点个Star,欢迎 加群 互相学习。

https://github.com/qq44924588...

我是小智,公众号「大迁世界」做者,对前端技术保持学习爱好者。我会常常分享本身所学所看的干货,在进阶的路上,共勉!

关注公众号,后台回复福利,便可看到福利,你懂的。

clipboard.png

相关文章
相关标签/搜索