乐趣区

关于javascript:如何用-JS-一次获取-HTML-表单的所有字段

作者:VALENTINO GAGLIARDI
译者:前端小智
起源:valentinog
挪动端浏览:https://mp.weixin.qq.com/s/rj…


点赞再看,养成习惯

本文 GitHub https://github.com/qq44924588… 上曾经收录,更多往期高赞文章的分类,也整顿了很多我的文档,和教程材料。欢送 Star 和欠缺,大家面试能够参照考点温习,心愿咱们一起有点货色。


问:如何用 JS 一次获取 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>

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

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

从事件 target 获取表单字段

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

而后,应用 this.elementsevent.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.elementsevent.target.elements,只有在事后晓得所有字段并且它们保持稳定的状况下,能力应用。

应用 FormData 构建具备所有字段的对象,之后能够转换,更新或将其发送到近程 API。*


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

代码部署后可能存在的 BUG 没法实时晓得,预先为了解决这些 BUG,花了大量的工夫进行 log 调试,这边顺便给大家举荐一个好用的 BUG 监控工具 Fundebug。


交换

干货系列文章汇总如下,感觉不错点个 Star,欢送 加群 互相学习。

https://github.com/qq44924588…

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

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

退出移动版