如何用 JS 一次获取 HTML 表单的所有字段 ()
作者:VALENTINO GAGLIARDI
译者:前端小智
来源:valentinog
有梦想,有干货,微信搜索 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。问:如何用 JS 一次获取 HTML 表单的所有字段 ?
本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试完整考点、资料以及我的系列文章。
考虑一个简单的 HTML 表单,用于将任务保存在待办事项列表中:
【如何用 JS 一次获取 HTML 表单的所有字段 ()】上面每个字段都有对应的的
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 = https://www.it610.com/article/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 = https://www.it610.com/article/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 = https://www.it610.com/article/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 = https://www.it610.com/article/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。
文章图片
推荐阅读
- 任时光绽放成六月繁花
- 我从来不做坏事
- 考研英语阅读终极解决方案——阅读理解如何巧拿高分
- 樱花雨
- 如何寻找情感问答App的分析切入点
- 【故障公告】周五下午的一次突发故障
- 拍照一年啦,如果你想了解我,那就请先看看这篇文章
- mybatisplus如何在xml的连表查询中使用queryWrapper
- MybatisPlus使用queryWrapper如何实现复杂查询
- 我要我们在一起(二)