您现在的位置是:亿华云 > IT科技类资讯
如何用 JS 一次获取 HTML 表单的所有字段 ?
亿华云2025-10-03 02:16:56【IT科技类资讯】3人已围观
简介问:如何用 JS 一次获取 HTML 表单的所有字段 ?考虑一个简单的 HTML 表单,用于将任务保存在待办事项列表中:<form><labelfor="name">用户名&l
问:如何用 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。
作者:VALENTINO GAGLIARDI 译者:前端小智 来源:valentinog
原文:https://www.valentinog.com/blog/form-data/
本文转载自微信公众号「CSS特效世界」,可以通过以下二维码关注。转载本文请联系CSS特效世界公众号。
很赞哦!(21273)