共计 2305 个字符,预计需要花费 6 分钟才能阅读完成。
作者:VALENTINO GAGLIARDI
译者:前端小智
起源:valentinog
有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。
本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。
问:如何用 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);
}
})
除了上述办法之外,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。*
原文:https://www.valentinog.com/bl…
代码部署后可能存在的 BUG 没法实时晓得,预先为了解决这些 BUG,花了大量的工夫进行 log 调试,这边顺便给大家举荐一个好用的 BUG 监控工具 Fundebug。
交换
文章每周继续更新,能够微信搜寻 【大迁世界】 第一工夫浏览,回复 【福利】 有多份前端视频等着你,本文 GitHub https://github.com/qq449245884/xiaozhi 曾经收录,欢送 Star。