在HTML中,表单是由
// HTMLFormElement继承了HTMLElement;因此它拥有HTML元素具有的默认属性,别且还独有自己的属性和方法;
2.提交表单
(1).通过事件对象,可以阻止submit的默认行为,submit事件的默认行为就是携带数据跳转到指定页面;
(2).我们可以使用submit()方法来自定义触发submit事件;也就是说,并不一定非要点击submit按钮才能提交;
(3).重复提交 // 当一条数据提交到服务器的时候会出现延迟等长时间没反映,导致用户不停的点击提交, // 从而使得重复提交了很多相同的请求,或造成错误或写入数据库多条相同信息;
// 解决重复提交方案 // 第一种:提交之后,立刻禁用点击按钮; document.getElementById('sub').disabled = true; // 将按钮禁用; // 第二种:提交之后,取消后续的表单提交操作; var flag = false; // 设置一个监听变量; if(flag == true)return; // 如果存在则返回退出事件; flag = true; // 否则确定是第一次,改变监听变量的值;
// 表单处理中,建议使用HTMLDOM,它有自己的elements属性,该属性是表单中所有元素的集合; fm.elements[0]; // 获取第一个表单字段元素; fm.elements['user']; // 获取name值是user的表单字段元素; fm.elements.length; // 获取所有表单字段的数量;
事件名 说明 blur 当字段失去焦点时触发; change 对于和元素,在改变value并失去焦点时触发;对于元素,在改变选项时触发; focus 当前字段获取焦点时触发;
EventUtil.addHandler(textBox,'blur',function(evt){ // 失去焦点事件; evt = EventUtil.getEvent(evt); var target = EventUtil.getTarget(evt); if(/[^\d]/.test(target.value)){ // 输入非数值字符时; target.style.backgroundColor = 'red'; // 文本框背景变成红色; }else{ target.style.backgroundColor = ''; } });
EventUtil.addHandler(textBox,'change',function(evt){ // 改变value值且失去焦点事件; evt = EventUtil.getEvent(evt); var target = EventUtil.getTarget(evt); if(/[^\d]/.test(target.value)){ target.style.backgroundColor = 'red'; // 文本框变成红色; }else{ target.style.backgroundColor = ''; } });
// 一种是单行文本框
// 一种是多行文本框;
// 虽然在字面上有value值,而却没有,但可以通过value获取它们的值; var textField = fm.elements[0]; var areaField = fm.elements[1]; alert(textField.value+','+areaField.value); // 得到和的value值; // PS:使用表单的value是最推荐的,它是HTMLDOM中的属性,不建议使用标准的DOM的方法getAttribute(); // 原因是:对value属性的修改,不一定反映在DOM中;
// defaultValue:得到原本的value值;不会因为值的改变而变化; alert(textField.defaultValue); // 得到最初设置的value值;
// 选取部分文本 // 在使用文本框内容的时候,我们有时要直接选定部分文本,这个行为还没有标准; // Firefox的解决方案是:setSelectionRange()方法;它接受两个参数:索引和长度; textField.setSelectionRange(0,1); // 选择第一个字符; textField.setSelectionRange(0,textField.value.length); // 选择全部; // IE8以下不支持这种写法,可以使用IE的范围操作代替; var range = textField.createTextRange(); // 创建一个文本范围对象; range.collapse(true); // 将指针移动到起点; range.moveStart('character',0); // 移动指针,character表示逐字移动; range.moveEnd('character',1); // 移动终点; range.select(); // 焦点选定;
// 选择部分文本兼容函数 function selectText(text,start,stop){ if(text.setSelectionRange){ text.setSelectionRange(start,stop); text.focus(); }else if(text.createTextRange){ var range = text.createTextRange(); range.collapse(true); range.moveStart('character',start); range.moveEnd('character',sotp-start); range.select(); } }
// 与select()方法对应的,是一个select事件,可以选中文本框文本后触发; addEvent(textField,'select',function(){ alert(this.value); // IE事件需要传递this才可以这么写; });
选择框是通过和元素创建的;
属性/方法 说明 add(new,rel) 插入新元素,并指定位置; multiple 布尔值,是否允许多项选择; options 元素的HTMLCollection集合; remove(index) 移除给定位置的选项; selectedIndex 基于0的选中项的索引,如果没有选中项,则值为-1; size 选择框中可见的行数;
// 在DOM中,每个元素都有一个HTMLOptionElement对象,以便访问数据; HTMLOptionElement对象 属性 说明 index 当前选项在options集合中的索引; label 当前选项的标签; selected 布尔值,表示当前选项是否被选中; text 选项的文本; value 选项的值;
alert(city.options[0].text); // 上海text,获取text值; alert(city.options[0].value); // 上海value,获取value值; // PS:操作select时,最好使用HTMLDOM,以为浏览器兼容性比较好; // 如果使用标准DOM,会因为不同的浏览器导致不同的结果; // PS:当选项没有value值的时候,IE会返回空字符串,其他浏览器会返回text值;
对于只能选择一项的选择框,使用selectedIndex属性最为简单;
通过option的属性selected(布尔值),也可以设置定位某个索引,设置为true即可; city.options[0].selected = true; // 设置第一个索引;
selected和selectedIndex区别: 1.selected是返回的布尔值;所以一般用于判断上; 2.selectedIndex返回的是数值,一般用于设置和获取;
(2).Option构造函数 var option = new Option('北京 text','北京 value'); city.appendChild(option); // IE出现bug;
(3).使用add()方法来添加选项: var option = new Option('北京 text','北京 value'); city.add(option,0); // 0,表示添加到第一位; // PS:在DOM规定,add()中两个参数是必须的,如果不正确索引,那么第二个参数设置null即可,即默认移入最后一个选项; // 但在IE中第二个参数是可选的,所以设置null表示放入不存在的位置,导致失踪; // 为了兼容性,可以传递undefined即可兼容; city.add(option,null); // IE不显示了; city.add(option,undefined); // 兼容;
选择框提供了一个index属性,可以得到当前选项的索引值,和selectedIndex的区别是,一个是选择框对象的调用,一个是选项对象的调用;