JavaScript DOM 学习第五章 表单简介


Posted in Javascript onFebruary 19, 2010

因为每一个表单的检测项都不同,所以我也不能给你一个万能的代码。你需要用我在这一章介绍的这些元素构建自己的检测函数。我在后面一张还有一个例子,你也可以参考。

在这一章我会首先讨论一下用JavaScript来检测表单的局限性,然后会解释一下提交时间处理程序,然后是表单本身的一些方法和属性。最后就是如何访问表单元素。

这里还有一篇Jeff Howden的介绍表单的使用错误和解决办法。Forms & JavaScript Living Together in Harmony
局限性
首先,你需要了解当用户提交了表单之后JavaScript的检测代码会做什么:
1、JavaScript检测表单时可能会像下面这样。如果代码发现了一个错误,那么提交就会暂停,然后给用户一个警告让他输入正确的数据。
2、如果没有什么错误或者JavaScript是关闭的那么表单内容就发送到服务器端。
3、如果服务器端的脚本发现了错误,就会返回一些错误信息。在这种情形下,用户需要返回表单然后重新填写数据再次提交。
4、如果没有错误发生,那么服务器端完成必要的工作并显示感谢信息。
就像你所看到的,数据在提交过程中会检测两次:一次是JavaScript一次是服务端。服务端检测总是可行的,而且是可靠的。JavaScript的检测只有在用户开启JavaScript功能的时候才有用,那么既然服务端总是可靠有效,并且与用户使用的浏览器无关,那么为什么还需要JavaScript检测呢?
JavaScript检测是服务器端检测的一个有效补充,因为他能在数据发往服务器端的时候先检测一遍。这样用户就不用使用后退按钮回去修改表单内容,那样会很麻烦,而且在寻找填错的内容也是一件相当麻烦的事情。所以JavaScript检测比服务器端检测对用户的使用体验帮助更大。
所以JavaScript不是一个完全的检测机制,但是作为服务器端的补充和对用户的友好性来讲还是一个不错选择。所以我建议使用这两种检测机制,既满足了用户的使用体验要求又保证了程序的安全性。
onsubmit
当你使用JavaScript来检测表单的时候,第一个事情就是创建onsubmit的事件处理程序。这个程序会在用户提交表单的时候运行。这个程序会检测某些字段是否有值填写,那些复选框是否选择了至少一个,或者其他的你需要检测内容。
代码如下:

<form action="something.pl" onsubmit="return checkscript()">

checkscript()就是这个程序的名字。这段代码需要返回true或者false。如果返回的是false,那么表单就不会被提交,不论返回true还是false代码都会停止运行。
所以生成的代码如下:
function checkscript() { 
    if (some value is/is not something) { 
        // something is wrong 
        alert('alert user of problem'); 
        return false; 
    } 
    else if (another value is/is not something) { 
        // something else is wrong 
        alert('alert user of problem'); 
        return false; 
    } 
    // If the script makes it to here, everything is OK, 
    // so you can submit the form 
    return true; 
}

当然这段代码可以写的很复杂,如果你需要检测很多表单项目或者一大堆的单选框。基本思想就是这样了:你遍历表单里的每一个需要检查的元素,如果发现了错误就返回false,然后代码停止运行,表单也不会被提交。
当你发现了错误的时候,你应该提醒用户。可以用一个警告框,不过今天大多数的办法是生成一条错误信息然后添加在错误条目的后面。
只有在最后地方,你检查过了所有的元素并且没有发现错误,那么你就返回true,表单就会被提交。
表单的方法和属性
JavaScript对于处理表单还有一些内建的方法和属性。其中三个比较重要:
你可以用submit()方法来提交表单。提交页面的第一个表单你可以写:
document.forms[0].submit() 
注意当用户使用JavaScript提交表单的时候,表单的事件处理程序就不起作用了。 
重置表单,你可以: 
[code] document.forms[0].reset() 
我假设,没有做测试,你如果使用这个方法,那么重置表单的事件处理程序也就不会执行。 
最后你可以修改表单的ACTION项: 
[code] document.forms[0].action = 'the_other_script.pl'; 
如果表单在某些情况需要提交给其他页面的时候这个方法就相当方便。 
访问表单元素 
表单的有效性检测需要访问到表单的元素才能知道用户填了什么内容进去。所以首先我们需要根据Level 0 DOM来访问表单。一般这样写: 
[code] document.forms[number].elements[number] 
当页面加载之后,JavaScript就会生成一个forms数组用来存储页面上所有的表单。所以第一个表单就是forms[0],第二个就是forms[1]等等。 
JavaScript把表单里面的每个元素也存储进了一个数组。第一个元素就是elements[0],第二个就是elements[1]。所有的input,select,textarea都是一个元素。 
有些时候,最好还是使用表单和元素的name比较好。在HTML中,你需要给每个元素命名,比如: 
[code] <form name="personal" action="something.pl" onsubmit="return checkscript()"> 2 <input type=text size=20 name=name> 3 <input type=text size=20 name=address> 4 <input type=text size=20 name=city> 5 </form> 
现在你就可以通过下面的方法来访问元素: 
[code] document.personal.name 2 document.personal.address 3 document.personal.city 
使用name的好处就在于你能把页面的所有元素顺序打乱的时候代码依然能够运行,如果用数组就不行。比如上面例子中的city的输入框是document.forms[0].elements[2],但是当你把他放在第一个的时候就变成了document.forms[0].element[0],这时候你就得改代码了。 
值的检测 
当然,最重要的事情还是找出用户填进去的值或者选择了的复选框。有些时候你还想填一些其他信息在表单里。 
下面的这些小段的代码能够帮助你访问到表单里的元素。所有的都是把用户输入保存在user_input变量中。之后,你就可以检测有效性了。 
Texts,textarea和隐藏的字段 
非常简单: 
[code] user_input = document.forms[0].text.value

其中text就是文本框或者textarea或者隐藏字段的name。value属性就会给出这些元素的文本,然后存储在user_input里。
直接写也可以:
document.forms[0].text.value = 'The new value';

Select Boxes
这也很简单:
user_input = document.forms[0].select.value;

要更改他的选择项目,就必须修改selectedIndex,比如:
document.forms[0].select.selectedIndex = 2;

现在第三个选项就被选择了。
旧的浏览器
在旧的浏览器里面select boxes没有value属性,那么:
var selectBox = document.forms[0].select; 
user_input = selectBox.options[selectBox.selectedIndex].value

首先找出用户选择了的项目。document.forms[0].select.selectedIndex给出了选择项目的编号。JavaScript已经创建了一个包含所有select boxes选项的options数组。所以通过这个数组就能知道用户选择了什么,然后存储在user_input里面。
checkboxes
checkboxes有一些小小的不同。我们已经知道了他的值,但是需要知道用户是否选择了他。checked属性可以告诉我们。他有true和false两个值。
那么:
if (document.forms[0].checkbox.checked) { 
user_input = document.forms[0].checkbox.name 
}

checkbox是复选框的名字。如果复选框被选择了,我们就得到名字(你也可以选择得到值)然后传递给user_input。
选择一个复选框可以:
document.forms[0].checkbox.checked = true

单选框
不幸的是,你不能一下子就找到哪个单选框被选中了。只能在遍历之后查找checked属性为true的那一项。
for (i=0;i<document.forms[0].radios.length;i++) { 
if (document.forms[0].radios[i].checked) { 
user_input = document.forms[0].radios[i].value; 
} 
}

radios就是这一组单选框的名字。
注意document.forms[0].radios是包含所有单选框的数组,循环检测是否checked的属性为true。如果是则传递个user_input。
document.forms[0].radios.length返回所有单选框的数目。
如果选择一个单选框,我们可以设置它的checked的值为true:
document.forms[0].radios[i].checked = true;

翻译地址:http://www.quirksmode.org/js/forms.html
转载请保留以下信息
作者:北玉(tw:@rehawk)
Javascript 相关文章推荐
jquery入门—选择器实现隔行变色实例代码
Jan 04 Javascript
在js文件中如何获取basePath处理js路径问题
Jul 10 Javascript
javascript引擎长时间独占线程造成卡顿的解决方案
Dec 03 Javascript
JavaScript获取页面中表单(form)数量的方法
Apr 03 Javascript
Layui 设置select下拉框自动选中某项的方法
Aug 14 Javascript
微信小程序 拍照或从相册选取图片上传代码实例
Aug 28 Javascript
浅谈layui里的上传控件问题
Sep 26 Javascript
JS实现打字游戏
Dec 17 Javascript
js代码实现轮播图
May 04 Javascript
微信小程序实现多图上传
Jun 19 Javascript
JavaScript实现网页tab栏效果制作
Nov 20 Javascript
使用Vue.js和MJML创建响应式电子邮件
Mar 23 Vue.js
JavaScript DOM学习第四章 getElementByTagNames
Feb 19 #Javascript
JavaScript DOM 学习第三章 内容表格
Feb 19 #Javascript
JavaScript DOM 学习第二章 编辑文本
Feb 19 #Javascript
JavaScript DOM学习第一章 W3C DOM简介
Feb 19 #Javascript
JavaScript 题型问答有答案参考
Feb 17 #Javascript
JavaScript 学习技巧
Feb 17 #Javascript
JavaScript Timer实现代码
Feb 17 #Javascript
You might like
这东西价格,可以买几台TECSUN S-2000
2021/03/02 无线电
php中$_REQUEST、$_POST、$_GET的区别和联系小结
2011/11/23 PHP
DEDECMS首页调用图片集里的多张图片
2015/06/05 PHP
Alliance vs Liquid BO3 第三场2.13
2021/03/10 DOTA
form中限制文本字节数js代码
2007/06/10 Javascript
JS 判断代码全收集
2009/04/28 Javascript
原生javascript和jquery判断浏览器版本等信息
2013/07/04 Javascript
jQuery ajax serialize() 方法使用示例
2014/11/02 Javascript
javascript原始值和对象引用实例分析
2015/04/25 Javascript
详解iframe与frame的区别
2016/01/13 Javascript
jQuery解决浏览器兼容性问题案例分析
2016/04/15 Javascript
全面解析JavaScript中“&amp;&amp;”和“||”操作符(总结篇)
2016/07/18 Javascript
教大家轻松制作Bootstrap漂亮表格(table)
2016/12/13 Javascript
JavaScript闭包_动力节点Java学院整理
2017/06/27 Javascript
React Native 自定义下拉刷新上拉加载的列表的示例
2018/03/01 Javascript
jQuery实现的简单对话框拖动功能示例
2018/06/05 jQuery
vue-cli3访问public文件夹静态资源报错的解决方式
2020/09/02 Javascript
在react项目中使用antd的form组件,动态设置input框的值
2020/10/24 Javascript
python将多个文本文件合并为一个文本的代码(便于搜索)
2011/03/13 Python
Python实现进程同步和通信的方法
2018/01/02 Python
Python实现繁体中文与简体中文相互转换的方法示例
2018/12/18 Python
如何使用Python进行OCR识别图片中的文字
2019/04/01 Python
python爬虫项目设置一个中断重连的程序的实现
2019/07/26 Python
使用Python代码实现Linux中的ls遍历目录命令的实例代码
2019/09/07 Python
Django REST Framework之频率限制的使用
2019/09/29 Python
python+selenium+PhantomJS抓取网页动态加载内容
2020/02/25 Python
Python figure参数及subplot子图绘制代码
2020/04/18 Python
简单了解python关键字global nonlocal区别
2020/09/21 Python
纯DOM+CSS3实现简单的小风车动画
2016/09/27 HTML / CSS
linux面试相关问题
2012/08/11 面试题
《长城》教学反思
2014/02/14 职场文书
《理想的风筝》教学反思
2014/04/11 职场文书
医德医魂心得体会
2014/09/11 职场文书
2015年度酒店客房部工作总结
2015/05/25 职场文书
2015年重阳节活动主持词
2015/07/30 职场文书
微信小程序基础教程之echart的使用
2021/06/01 Javascript