创新互联长期为上千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为乌鲁木齐企业提供专业的成都网站建设、网站建设,乌鲁木齐网站改版等技术服务。拥有十年丰富建站经验和众多成功案例,为您定制开发。
问:如何用 JS 一次获取 HTML 表单的所有字段 ?
考虑一个简单的 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 = 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表单中获取所有字段,可以使用:
使用FormData构建具有所有字段的对象,之后可以转换,更新或将其发送到远程API。*
网页名称:如何用JS一次获取HTML表单的所有字段?
网址分享:http://www.mswzjz.cn/qtweb/news31/16081.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能