How to use a map method on form elements(如何在表单元素上使用映射方法)
本文介绍了如何在表单元素上使用映射方法的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想创建一个表单元素的所有名称的列表。 但是,使用以下代码时,我得到了错误: "inputs.map不是函数"
我知道inputs
不是数组,但我不确定如何使This.map
起作用?
数据-lang="js"数据-隐藏="假"数据-控制台="真"数据-巴贝尔="假">
function process(form) {
console.dir(form)
var inputs = form.elements
for (let i = 0; i < inputs.length; i++) {
console.log(i+':'+inputs[i].name+': '+inputs[i].value);
}
let names = inputs.map( e => e.name )
console.log(names)
}
<form name=form1 method=none>
firstname: <input name=lastn value="a" type=text>
<br>lastname: <input name=firstn value="b" type=text>
<br>zipcode: <input name=zip value="c" type=text>
<br>ip: <input name=ip value="127.0.0.1" type=text disabled>
<br><input onclick="process(this.parentNode)" name=button type=button value="register">
</form>
btw要运行代码,您必须单击"注册"按钮(因为这是一个"onClick"调用)
推荐答案
HTMLFormElement.elements
是一个HTMLFormControlsCollection
,它是一个类似数组的对象,而不是一个实际的数组。使用Array.from()
将其转换为数组:
function process(form) {
var inputs = Array.from(form.elements)
const names = inputs.map(e => e.name)
console.log(names)
}
<form name=form1 method=none>
firstname: <input name=lastn value="a" type=text>
<br>lastname: <input name=firstn value="b" type=text>
<br>zipcode: <input name=zip value="c" type=text>
<br>ip: <input name=ip value="127.0.0.1" type=text disabled>
<br><input onclick="process(this.parentNode)" name=button type=button value="register">
</form>
这篇关于如何在表单元素上使用映射方法的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:如何在表单元素上使用映射方法


基础教程推荐
猜你喜欢
- 角度Apollo设置WatchQuery结果为可用变量 2022-01-01
- 在for循环中使用setTimeout 2022-01-01
- 有没有办法使用OpenLayers更改OpenStreetMap中某些要素 2022-09-06
- Karma-Jasmine:如何正确监视 Modal? 2022-01-01
- 当用户滚动离开时如何暂停 youtube 嵌入 2022-01-01
- 动态更新多个选择框 2022-01-01
- 在 JS 中获取客户端时区(不是 GMT 偏移量) 2022-01-01
- 我什么时候应该在导入时使用方括号 2022-01-01
- 响应更改 div 大小保持纵横比 2022-01-01
- 悬停时滑动输入并停留几秒钟 2022-01-01