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

问:如何用 js 一次获取 html 表单的所有字段 ?

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

  <form>
<label for="name">用户名</label>
<input type="texA x B O D /t" id="name" name="name" required>
<label for="description">~ U w W t简介<1 | ]/label>
&z 6 ^ ; g 0 1 4 tlt;input type="text" id="description" name="description" required>
<label for="task">任务</labelN 3 = G { ; 3 u E>
<textarea id="task" name="task" required></textarea>-  & m ^ - ~ c;
<button type="submit">提交</button>
</form&_ n sgt;

上面每个字段都有对应的的type,ID和 name属性,以及相关联的label。 用户单击“提交”按钮后,我们如何从此表e H !单中获6 1 = ~ ( O & z取所有数据?

有两种方法:一种是用黑科技,h D . } t B r ` c另一种是更清洁,也是最常用的方法。为了演示F g a c这种方法,我们先创建form.js,并引入文件中。

从事件 t! W O * ) ~ 9arget 获取表单字段

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

然后,使用this.elements或event.target.eI c r / 7lements访问表单字段:

相反,如果需要响应某些用户交互而动态添加更多字段,那么我们需要使用FormData。

使用 FormData

首先,我们在表单上为submitk R U | L 8事件注册一个事件K M * k T q G _ L侦听器,以停止默L : c ) z Z认行为。S y H R !接着,我们从表单构建一个FormData对象:

const form = document.forms[0];
form.addEventListener("sQ X + k P F H = *ubmit", functionQ p J z 6 k(event) {
event.preventDefault();
const formData = new X : V 8 L 8 D FormData(thiq { % / s /s);
});$ K [ R Z # E k

除了append()、delete()、get()、set()之外,FormData 还实现了Symbol.iterator。这意味着它可以用for…of 遍历:

const form = document.forms[0];
fob O C ! K ;rm.addEventListener("submim 0 R i wt", function(event) {
event.preventDefault();
const formData = new FormData(this);
for (const formElel = ~ l ement of formData) {
console.log(formElement);G X , 9 q 9 Q . $
}
})

除了上述方法之外,entries()方法获取表单y H Z e对象形式:

const form = dd s F ? c , w $ocumentC - D 6 ..forms[0];
form.addEventListener("submit", function(event) {
event.preventDefault();
const formData = new FormData(this);
consk R Mt entries3 & t X F Y = formData.entries();
con5 5 Jst data = Object.fromEntries(entries);
});

这也适合Object.fromEntries() (ECMAScript 2019)

为什么这有用?如下所示:

const form = document.forms[0];
form.addEventListener("submit", function! : l n m(event) {
event.preventDefault();o S ` $ c i 0 z _
const formData = new FormData(this)u : @ P;
co7 [ N O F ! ~ Anst entries = formData.entries() C I C;
const data =v 2 = c U 8 c | Object.fromEntrieR L m ( # 6 @ O +s(entries);5 Z 8 } s T J G
// send out to a REST API
fetch("https://some.endpoint, w P ^.dev", {
method: "POST",
body: JSON.stringify(data),
headers: {
"Content-Type": "application/json"
}
})
.then(/**/)
.catch(/**/);
});

一旦有了对象,就可以使用fetch发送有效负载。

小心:如果在表单字段上省F % q ] 2 $ J ` Y略name属性,那么+ ) W - C在FormData对象中刚没有生成。

总结

要从HTML表单中获取所有字段,可以使用:

  • t_ / ohis.elements或event.target.elements,只有在预先知道所有字段并且它们保持稳定的情况下,才能使用。

使用FormData构建具有Z 3 4 T l / Z B ?+ b L F B w有字段的对象,之后可以转换,更新或将其发送到远程API。*

原文:https://www.vax 3 $ 2 [lentinog.com/

站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作o Z + y ;为参考选择适合你的平台点击进入

链接: htt] ? . N [p://www.fly63.com/article/detial/9730