目录
用JavaScript操作表单和操作DOM是类似的,因为表单本身也是DOM树。
不过表单的输入框、下拉框等可以接收用户输入,所以用JavaScript来操作表单,可以获得用户输入的内容,或者对一个输入框设置新的内容。
HTML表单的输入控件主要有以下几种:
如果我们获得了一个<input> 节点的引用,就可以直接调用value 获得对应的用户输入值:
这种方式可以应用于text 、password 、hidden 以及select 。但是,对于单选框和复选框, value 属性返回的永远是HTML预设的值,而我们需要获得的实际是用户是否“勾上了”选项,
所以应该用checked 判断:
设置值和获取值类似,对于text 、password 、hidden 以及select ,直接设置value就可以:
对于单选框和复选框,设置checked 为true 或false 即可。
JavaScript可以以两种方式来处理表单的提交(A JAX方式在后面才学习)
方式一通过<form> 元素的submit() 方法提交一个表单,例如,响应一个button 的click 事件,在JavaScript代码中提交表单:
这种方式的缺点是扰乱了浏览器对form的正常提交。浏览器默认点击<button type="submit"> 时提交表单,或者用户在最后一个输入框按回车键。因此,第二种方式是响应<form> 本身的
onsubmit 事件,在提交form时作修改:
在检查和修改<input> 时,要充分利用<input type="hidden"> 来传递数据。
出于安全考虑,提交表单时不传输明文口令,而是口令的MD5。一般人员会直接修改<input> :
这个做法看上去没啥问题,但用户输入了口令提交时,口令框的显示会突然从几个* 变成32个* (因为MD5有32个字符)。
要想不改变用户的输入,可以利用<input type="hidden"> 实现:
原文:https://www.cnblogs.com/koudada/p/14857477.html