<返回更多

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

2020-10-12    
加入收藏

问:如何用 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>

上面每个字段都有对应的的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);
  }})
如何用 JS 一次获取 HTML 表单的所有字段?

 


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

 

除了上述方法之外,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表单中获取所有字段,可以使用:

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

 

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

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

声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多资讯 >>>