JavaScript表单处理(下)

内容提纲:

1.文本框脚本

2.选择框脚本

发文不易,转载请亲注明链接出处,谢谢!

 

一.文本框脚本

在HTML中,有两种方式来表现文本框:

一种是单行文本框<input type="text">;

一种是多行文本框<textarea>。

虽然在HTML中<input>有value值,而<textarea>却没有,但在JS中都可以通过value获取他们的值。

var textField =
fm.elements[0];

var areaField =
fm.elements[1];

alert(textField.value + ‘,‘
+ areaField.value);        //得到value值

PS:使用表单的value是最推荐使用的,它是HTML DOM中的属性,不建议使用标准DOM的方法。也就是说不要使用getAttribute()获取value值。原因很简单,浏览器兼容有问题而且,对value属性的修改,不一定会反映在DOM中。

alert(areaField.getAttribute(‘value‘));   
//兼容性会有问题,IE可以获取,非IE获取不到

alert(textField.getAttribute(‘value‘));    
//标准DOM无法获取更改后的value

除了value值,还有一个属性对应的是defaultValue,可以得到原本的value值,不会因为值的改变而变化。

alert(textField.defaultValue);
             
             
//得到最初的value值

选择文本

使用select()方法,可以将文本框里的文本选中,并且将焦点设置到文本框中。

textField.select();  
             
             
             
//选中文本框中的文本

选择部分文本

在使用文本框内容的时候,我们有时要直接选定部分文本,这个行为还没有标准。Firefox的解决方案是:setSelectionRange()方法。这个方法接受两个参数:索引和长度。

textField.setSelectionRange(0,1); 
             
             
       //选择第一个字符

textField.focus();   
             
             
             
//焦点移入(这样可以修改里面的文本)

textField.setSelectionRange(0,
textField.value.length);      
       //选择全部

textField.focus();          
             
             
             
       //焦点移入

除了IE,其他浏览器都支持这种写法(IE9+支持),那么IE想要选择部分文本,可以使用IE的范围操作。

var range =
textField.createTextRange();     
       //创建一个文本范围对象

range.collapse(true);     
             
             
       //将指针移到起点

range.moveStart(‘character‘, 0);    
             
       //移动起点,character表示逐字移动

range.moveEnd(‘character‘,
1);            
             
//移动终点,同上

range.select();
             
             
             
       //焦点选定

PS:关于IE范围这儿不详细讲解。并且W3C也有自己的范围。

PS:非IE从第N个到第M个位置,IE是从第N个开始选择M个。

//选择部分文本实现跨浏览器兼容


 1 function selectText(text, start, stop) {
2
3 if (text.setSelectionRange) {
4
5 text.setSelectionRange(start, stop);
6
7 text.focus();
8
9 } else if (text.createTextRange) {
10
11 var range = text.createTextRange();
12
13 range.collapse(true);
14
15 range.moveStart(‘character‘, start);
16
17 range.moveEnd(‘character‘, stop - start); //IE用终点减去起点得到字符数
18
19 range.select();
20
21 }
22
23 }
24
25

使用select事件,可以选中文本框文本后触发,得到文本框中的全部文本(取得选择的文本见下一部分)。

addEvent(textField,
‘select‘, function () {

alert(this.value);    
             
//得到全部文本,IE事件需要传递this才可以这么写

});

取得选择的文本

如果我们想要取得选择的那个文本,就必须使用一些手段。目前为止,没有任何规范解决这个问题。Firefox为文本框提供了两个属性:selectionStart和selectionEnd

addEvent(textField,
‘select‘, function () {

alert(this.value.substring(this.selectionStart,
this.selectionEnd)
);

});

除了IE,其他浏览器均支持这两个属性(IE9+已支持)。IE不支持,而提供了另一个方案:selection对象,属于document。这个对象保存着用户在整个文档范围内选择的文本信息。

//浏览器兼容


 1 function getSelectText(text) {
2
3 if (typeof text.selectionStart == ‘number‘) { //非IE
4
5 return text.value.substring(text.selectionStart, text.selectionEnd);
6
7 } else if (document.selection) { //IE
8
9 return document.selection.createRange().text; //获取IE选择的文本
10
11 }
12
13 }

PS:有一个最大的问题,就是IE在触发select事件的时候,在选择一个字符后立即触发,而其他浏览器是选择想要的字符释放鼠标键后才触发。所以,如果使用alert()的话,导致跨浏览器的不兼容。我们没有办法让浏览器行为保持统一,但可以通过不去使用alert()来解决。

addEvent(textField,
‘select‘, function () {

//alert(getSelectText(this));   
             
       //导致用户行为结果不一致(不这样用)

document.getElementById(‘box‘).innerHTML = getSelectText(this);
//this指代textField

});

综合小案例:

html代码部分:


 1 <body>
2
3 <form id="myForm" name="yourForm">
4
5 姓名:<input type="text" name="user" value="text" /><br />
6
7 <p id="pox"></p>
8
9 <textarea name="content">textarea</textarea>
10
11 </form>
12
13 </body>

JS代码部分:


 1 addEvent(window, ‘load‘, function () {
2
3 var fm = document.getElementById(‘myForm‘);
4
5 var user = fm.elements[‘user‘];
6
7 var content = fm.elements[‘content‘];
8
9
10
11 //select 事件
12
13 addEvent(user, ‘select‘, function () {
14
15 document.getElementById(‘pox‘).innerHTML = getSelectText(user);
16
17 });
18
19
20
21 function getSelectText(text) {
22
23 if (typeof text.selectionStart == ‘number‘) {
24
25 return text.value.substring(text.selectionStart, text.selectionEnd);
26
27 } else if (document.selection) {
28
29 return document.selection.createRange().text;
30
31 }
32
33 }
34
35 });

过滤输入

过滤输入的两种模式(以纯数字为例):

  1. 禁止和屏蔽非数字键的输入,阻止非数字键的默认行为;

  2. 验证后取消,可以先输入非法字符,判断后取消非法字符文本。

       法1:屏蔽非数字键输入

  addEvent(areaField, ‘keypress‘, function (evt) {

var e = evt || window.event;

var charCode =
getCharCode(evt);      
       // getCharCode()跨浏览器获取字符编码(事件对象篇)

if
(!/\d/.test(String.fromCharCode(charCode)) && charCode > 8) { 
//条件阻止默认

preDef(evt);

}

});

PS前半段条件判断只有数字才可以输入,导致常规按键,比如光标键、退格键、删除键等无法使用。部分浏览器比如Firefox,需要解放这些键,而非字符触发的编码均为0;在Safari3之前的浏览器,也会被阻止,而它对应的字符编码全部为8,所以最后就加上charCode > 8的判断即可。

PS:当然,这种过滤还是比较脆弱的,我们还希望能够阻止裁剪、复制、粘贴和中文字符输入操作才能真正屏蔽掉这些。

如果要阻止裁剪、复制和粘贴,那么我们可以在剪贴板相关的事件上进行处理,JavaScript提供了六组剪贴板相关的事件:























事件名

说明

copy

在发生复制操作时触发

cut

在发生裁剪操作时触发

paste

在发生粘贴操作时触发

beforecopy

在发生复制操作前触发

beforecut

在发生裁剪操作前触发

beforepaste

在发生粘贴操作前触发

由于剪贴板没有标准,导致不同的浏览器有不同的解释。Safari、Chrome和Firefox中,凡是before前缀的事件,都需要在特定条件下触发。而IE则会在操作时之前触发带before前缀的事件。

如果我们想要禁用裁剪、复制、粘贴,那么只要阻止默认行为即可。


 1     addEvent(areaField, ‘cut‘, function (evt) {           //阻止裁剪
2
3 preDef(evt);
4
5 });
6
7 addEvent(areaField, ‘copy‘, function (evt) { //阻止复制
8
9 preDef(evt);
10
11 });
12
13 addEvent(areaField, ‘paste‘, function (evt) { //阻止粘贴
14
15 preDef(evt);
16
17 });

PS:当我们裁剪和复制的时候,我们可以访问剪贴板里的内容,但问题是FireFox,Opera浏览器不支持访问剪贴板。并且,不同的浏览器也有自己不同的理解。所以,这里我们就不在赘述。

最后一个问题影响到可能会影响输入的因素就是:输入法。我们知道,中文输入法,它的原理是在输入法面板上先存储文本,按下回车就写入英文文本,按下空格就写入中文文本。

有一种解决方案是通过CSS来禁止调出输入法:

style="ime-mode:disabled"   
             
             
//CSS直接编写

areaField.style.imeMode = ‘disabled‘;   
             
//或在JS里设置也可以

PS:但Chrome浏览器却无法禁止输入法调出。所以,为了解决Chrome浏览器的问题,最好还要使用正则验证已输入的文本。

//法2:验证后取消(建议使用)

addEvent(areaField,
‘keyup‘, function
(evt) {           
//keyup弹起的时候

this.value = this.value.replace(/[^\d]/g,
‘‘);    //把非数字都替换成空

});

自动切换焦点

为了增加表单字段的易用性,很多字段在满足一定条件时(比如长度),就会自动切换到下一个字段上继续填写。


1     <input type="text" name="user1" maxlength="1" />   //只能写1个
2
3 <input type="text" name="user2" maxlength="2" /> //只能写2个
4
5 <input type="text" name="user3" maxlength="3" /> //只能写3个


 1 //自动切换焦点
2
3 addEvent(fm.elements[‘a1‘], ‘keyup‘, tabForWard);
4
5 addEvent(fm.elements[‘a2‘], ‘keyup‘, tabForWard);
6
7 addEvent(fm.elements[‘a3‘], ‘keyup‘, tabForWard);
8
9
10
11 function tabForward (evt) {
12
13 var e = evt || window.event;
14
15 var target = getTarget(evt);
16
17 //判断当前长度是否和指定长度一致
18
19 if (target.value.length == target.maxLength) {
20
21             //遍历所有字段
22
23 for (var i =0; i < fm.elements.length; i ++) {
24
25                 //找到当前字段
26
27 if (fm.elements[i] == target) {
28
29                   //就把焦点移入下一个
30
31 fm.elements[i + 1].focus();
32
33                     //中途返回
34
35 return;
36
37 }
38
39 }
40
41 }
42
43 }
44
45

二.选择框脚本

下面内容基于以下HTML代码:


 1 <body>
2
3 <form id="myForm" name="yourForm">
4
5 <select name="city">
6
7 <option value="上海v">上海t</option>
8
9 <option value="南京v">南京t</option>
10
11 <option value="杭州v">杭州t</option>
12
13 <option>无</option>
14
15 </select>
16
17 </form>

选择框是通过<select>和<option>元素创建的,除了通用的一些属性和方法外,HTMLSelectElement类型还提供了如下的属性和方法:

HTMLSelectElement对象























属性/方法

说明

add(new,rel)

插入新元素,并指定位置

multiple

布尔值,是否允许多项选择

options

<option>元素的HTMLColletion集合

remove(index)

移除给定位置的选项

selectedIndex

基于0的选中项的索引,如果没有选中项,则值为-1

size

选择框中可见的行数

在DOM中,每个<option>元素都有一个HTMLOptionElement对象,以便访问数据,这个对象有如下一些属性:

HTMLOptionElement对象




















属性

说明

index

当前选项在options集合中的索引

label

当前选项的标签

selected

布尔值,表示当前选项是否被选中

text

选项的文本

value

选项的值

var city =
fm.elements[‘city‘];      
             
             
//HTMLSelectElement

alert(city.options);        
             
             
         //HTMLOptionsCollection

alert(city.options[0]);    
             
             
         //HTMLOptionElement

alert(city.type);     
             
             
               
//select-one

PS:选择框里的type属性有可能是:select-one,也有可能是:select-multiple,这取决于HTML代码中有没有multiple属性。

 

标准DOM方法(不推荐):

alert(city.options[0].firstChild.nodeValue);  
       //上海t,获取text值,不推荐的做法

alert(city.options[0].getAttribute(‘value‘));   
       //上海v,获取value值,不推荐的做法

HTML DOM 方法(推荐):

alert(city.options[0].text);    
             
             
//上海t,获取text值,推荐

alert(city.options[0].value);  
             
             
//上海v,获取value值,推荐

PS:操作select时,最好使用HTML
DOM,因为所有浏览器兼容的很好。而如果使用标准DOM,会因为不同的浏览器导致不同的结果。

PS:当选项没有value值的时候,IE会返回空字符串,其他浏览器会返回text值。

 

选择选项

对于只能选择一项的选择框,使用selectedIndex属性最为简单。

addEvent(city, ‘change‘,
function () {

alert(this.selectedIndex);      
             
             
//得到当前选项的索引,从0开始

alert(this.options[this.selectedIndex].text);  
//得到当前选项的text值

alert(this.options[this.selectedIndex].value);
//得到当前选项的value值

});

PS:如果是多项选择,他始终返回的是第一个项。

 

city.selectedIndex = 1;  
             
             
       //设置selectedIndex可以定位到某个索引

通过option的属性(布尔值)selected,也可以设置某个索引,设置为true即可。

city.options[0].selected = true;     
             
       //设置第一个索引

而selected(作用在option对象上)和selectedIndex(作用在select对象上)在用途上最大的区别是:selected是返回的布尔值,所以一般用于判断上;而selectedIndex是数值,一般用于设置和获取。

addEvent(city, ‘change‘,
function () {

if (this.options[2].selected == true)
{           //判断第三个选项是否被选定

alert(‘选择正确!‘);

}

});

 

添加选项

如需动态的添加选项我们有两种方案:标准DOM和Option构造函数

使用标准DOM添加:

var option =
document.createElement(‘option‘);

option.appendChild(document.createTextNode(‘北京t‘));

option.setAttribute(‘value‘, ‘北京v‘)

city.appendChild(option);

使用Option构造函数添加:

  var option = new Option(‘北京t‘, ‘北京v‘);

  city.appendChild(option);     
             
             
//IE出现bug

使用add()方法来添加:

  var option = new Option(‘北京t‘, ‘北京v‘);

  city.add(option, 0);       
             
             
       //0,表示添加到第一位

PS:DOM规定,add()中两个参数是必须的,如果不确定索引,那么第二个参数设置null即可,即默认移入最后一个选项。但IE中规定第二个参数是可选的,所以设置null表示放入不存在的位置,导致失踪,为了兼容性,我们传递undefined即可兼容。

city.add(option, null);   
             
             
       //IE不显示了

city.add(option,
undefined);            
             
      
//
最佳兼容方案

 

移除选项

有三种方式可以移除某一个选项:DOM移除、remove()方法移除和null移除

city.removeChild(city.options[0]);
             
       //DOM移除

city.remove(0);     
             
             
             
//remove()
移除,推荐

city.options[0] = null;   
             
             
       //null移除

PS:当第一项移除后,下面的项会自动往上移动,所以不停的移除第一项,即可全部移除。

移动选项

如果有两个选择框,把第一个选择框里的第一项移到第二个选择框里,并且第一个选择框里的第一项被移除。

var city =
fm.elements[‘city‘];      
             
             
//第一个选择框

var info = fm.elements[‘info‘];     
             
       //第二个选择框

info.appendChild(city.options[0]);   
             
      
//
移动,自我删除

 

排列选项

选择框提供了一个index属性,可以得到当前选项的索引值,和selectedIndex的区别是,selectedIndex是选择框对象(select)的调用,index是选项对象(option)的调用。

var option1 = city.options[1];

city.insertBefore(option1,
city.options[option1.index - 1]);      
       //往下移动移位

单选按钮

通过checked属性来获取单选按钮的值。

for (var i = 0; i <
fm.sex.length; i ++) {     
             
//循环单选按钮

if (fm.sex[i].checked ==
true) {         
       //遍历每一个找出选中的那个

alert(fm.sex[i].value);          
             
//得到值

}

}

PS:除了checked属性之外,单选按钮还有一个defaultChecked属性,它获取的是原本的checked按钮对象,而不会因为checked的改变而改变。

if
(fm.sex[i].defaultChecked == true) {

alert(fm.sex[i].value);

}

 

复选按钮

通过checked属性来获取复选按钮的值。复选按钮也具有defaultChecked属性

var love = ‘‘;

for (var i = 0; i <
fm.love.length; i ++) {

if (fm.love[i].checked
== true) {

love
+= fm.love[i].value;

}

}

alert(love);

For my
lover and 

Thank
you ,Mr.Lee!

---恢复内容结束---

内容提纲:

1.文本框脚本

2.选择框脚本

发文不易,转载请亲注明链接出处,谢谢!

 

一.文本框脚本

在HTML中,有两种方式来表现文本框:

一种是单行文本框<input type="text">;

一种是多行文本框<textarea>。

虽然在HTML中<input>有value值,而<textarea>却没有,但在JS中都可以通过value获取他们的值。

var textField =
fm.elements[0];

var areaField =
fm.elements[1];

alert(textField.value + ‘,‘
+ areaField.value);        //得到value值

PS:使用表单的value是最推荐使用的,它是HTML DOM中的属性,不建议使用标准DOM的方法。也就是说不要使用getAttribute()获取value值。原因很简单,浏览器兼容有问题而且,对value属性的修改,不一定会反映在DOM中。

alert(areaField.getAttribute(‘value‘));   
//兼容性会有问题,IE可以获取,非IE获取不到

alert(textField.getAttribute(‘value‘));    
//标准DOM无法获取更改后的value

除了value值,还有一个属性对应的是defaultValue,可以得到原本的value值,不会因为值的改变而变化。

alert(textField.defaultValue);
             
             
//得到最初的value值

选择文本

使用select()方法,可以将文本框里的文本选中,并且将焦点设置到文本框中。

textField.select();  
             
             
             
//选中文本框中的文本

选择部分文本

在使用文本框内容的时候,我们有时要直接选定部分文本,这个行为还没有标准。Firefox的解决方案是:setSelectionRange()方法。这个方法接受两个参数:索引和长度。

textField.setSelectionRange(0,1); 
             
             
       //选择第一个字符

textField.focus();   
             
             
             
//焦点移入(这样可以修改里面的文本)

textField.setSelectionRange(0,
textField.value.length);      
       //选择全部

textField.focus();          
             
             
             
       //焦点移入

除了IE,其他浏览器都支持这种写法(IE9+支持),那么IE想要选择部分文本,可以使用IE的范围操作。

var range =
textField.createTextRange();     
       //创建一个文本范围对象

range.collapse(true);     
             
             
       //将指针移到起点

range.moveStart(‘character‘, 0);    
             
       //移动起点,character表示逐字移动

range.moveEnd(‘character‘,
1);            
             
//移动终点,同上

range.select();
             
             
             
       //焦点选定

PS:关于IE范围这儿不详细讲解。并且W3C也有自己的范围。

PS:非IE从第N个到第M个位置,IE是从第N个开始选择M个。

//选择部分文本实现跨浏览器兼容


 1 function selectText(text, start, stop) {
2
3 if (text.setSelectionRange) {
4
5 text.setSelectionRange(start, stop);
6
7 text.focus();
8
9 } else if (text.createTextRange) {
10
11 var range = text.createTextRange();
12
13 range.collapse(true);
14
15 range.moveStart(‘character‘, start);
16
17 range.moveEnd(‘character‘, stop - start); //IE用终点减去起点得到字符数
18
19 range.select();
20
21 }
22
23 }
24
25

使用select事件,可以选中文本框文本后触发,得到文本框中的全部文本(取得选择的文本见下一部分)。

addEvent(textField,
‘select‘, function () {

alert(this.value);    
             
//得到全部文本,IE事件需要传递this才可以这么写

});

取得选择的文本

如果我们想要取得选择的那个文本,就必须使用一些手段。目前为止,没有任何规范解决这个问题。Firefox为文本框提供了两个属性:selectionStart和selectionEnd

addEvent(textField,
‘select‘, function () {

alert(this.value.substring(this.selectionStart,
this.selectionEnd)
);

});

除了IE,其他浏览器均支持这两个属性(IE9+已支持)。IE不支持,而提供了另一个方案:selection对象,属于document。这个对象保存着用户在整个文档范围内选择的文本信息。

//浏览器兼容


 1 function getSelectText(text) {
2
3 if (typeof text.selectionStart == ‘number‘) { //非IE
4
5 return text.value.substring(text.selectionStart, text.selectionEnd);
6
7 } else if (document.selection) { //IE
8
9 return document.selection.createRange().text; //获取IE选择的文本
10
11 }
12
13 }

PS:有一个最大的问题,就是IE在触发select事件的时候,在选择一个字符后立即触发,而其他浏览器是选择想要的字符释放鼠标键后才触发。所以,如果使用alert()的话,导致跨浏览器的不兼容。我们没有办法让浏览器行为保持统一,但可以通过不去使用alert()来解决。

addEvent(textField,
‘select‘, function () {

//alert(getSelectText(this));   
             
       //导致用户行为结果不一致(不这样用)

document.getElementById(‘box‘).innerHTML = getSelectText(this);
//this指代textField

});

综合小案例:

html代码部分:


 1 <body>
2
3 <form id="myForm" name="yourForm">
4
5 姓名:<input type="text" name="user" value="text" /><br />
6
7 <p id="pox"></p>
8
9 <textarea name="content">textarea</textarea>
10
11 </form>
12
13 </body>

JS代码部分:


 1 addEvent(window, ‘load‘, function () {
2
3 var fm = document.getElementById(‘myForm‘);
4
5 var user = fm.elements[‘user‘];
6
7 var content = fm.elements[‘content‘];
8
9
10
11 //select 事件
12
13 addEvent(user, ‘select‘, function () {
14
15 document.getElementById(‘pox‘).innerHTML = getSelectText(user);
16
17 });
18
19
20
21 function getSelectText(text) {
22
23 if (typeof text.selectionStart == ‘number‘) {
24
25 return text.value.substring(text.selectionStart, text.selectionEnd);
26
27 } else if (document.selection) {
28
29 return document.selection.createRange().text;
30
31 }
32
33 }
34
35 });

过滤输入

过滤输入的两种模式(以纯数字为例):

  1. 禁止和屏蔽非数字键的输入,阻止非数字键的默认行为;

  2. 验证后取消,可以先输入非法字符,判断后取消非法字符文本。

       法1:屏蔽非数字键输入

  addEvent(areaField, ‘keypress‘, function (evt) {

var e = evt || window.event;

var charCode =
getCharCode(evt);      
       // getCharCode()跨浏览器获取字符编码(事件对象篇)

if
(!/\d/.test(String.fromCharCode(charCode)) && charCode > 8) { 
//条件阻止默认

preDef(evt);

}

});

PS前半段条件判断只有数字才可以输入,导致常规按键,比如光标键、退格键、删除键等无法使用。部分浏览器比如Firefox,需要解放这些键,而非字符触发的编码均为0;在Safari3之前的浏览器,也会被阻止,而它对应的字符编码全部为8,所以最后就加上charCode > 8的判断即可。

PS:当然,这种过滤还是比较脆弱的,我们还希望能够阻止裁剪、复制、粘贴和中文字符输入操作才能真正屏蔽掉这些。

如果要阻止裁剪、复制和粘贴,那么我们可以在剪贴板相关的事件上进行处理,JavaScript提供了六组剪贴板相关的事件:























事件名

说明

copy

在发生复制操作时触发

cut

在发生裁剪操作时触发

paste

在发生粘贴操作时触发

beforecopy

在发生复制操作前触发

beforecut

在发生裁剪操作前触发

beforepaste

在发生粘贴操作前触发

由于剪贴板没有标准,导致不同的浏览器有不同的解释。Safari、Chrome和Firefox中,凡是before前缀的事件,都需要在特定条件下触发。而IE则会在操作时之前触发带before前缀的事件。

如果我们想要禁用裁剪、复制、粘贴,那么只要阻止默认行为即可。


 1     addEvent(areaField, ‘cut‘, function (evt) {           //阻止裁剪
2
3 preDef(evt);
4
5 });
6
7 addEvent(areaField, ‘copy‘, function (evt) { //阻止复制
8
9 preDef(evt);
10
11 });
12
13 addEvent(areaField, ‘paste‘, function (evt) { //阻止粘贴

14
15 preDef(evt);
16
17 });

PS:当我们裁剪和复制的时候,我们可以访问剪贴板里的内容,但问题是FireFox,Opera浏览器不支持访问剪贴板。并且,不同的浏览器也有自己不同的理解。所以,这里我们就不在赘述。

最后一个问题影响到可能会影响输入的因素就是:输入法。我们知道,中文输入法,它的原理是在输入法面板上先存储文本,按下回车就写入英文文本,按下空格就写入中文文本。

有一种解决方案是通过CSS来禁止调出输入法:

style="ime-mode:disabled"   
             
             
//CSS直接编写

areaField.style.imeMode = ‘disabled‘;   
             
//或在JS里设置也可以

PS:但Chrome浏览器却无法禁止输入法调出。所以,为了解决Chrome浏览器的问题,最好还要使用正则验证已输入的文本。

//法2:验证后取消(建议使用)

addEvent(areaField,
‘keyup‘, function
(evt) {           
//keyup弹起的时候

this.value = this.value.replace(/[^\d]/g,
‘‘);    //把非数字都替换成空

});

自动切换焦点

为了增加表单字段的易用性,很多字段在满足一定条件时(比如长度),就会自动切换到下一个字段上继续填写。


1     <input type="text" name="user1" maxlength="1" />   //只能写1个
2
3 <input type="text" name="user2" maxlength="2" /> //只能写2个
4
5 <input type="text" name="user3" maxlength="3" /> //只能写3个


 1 //自动切换焦点
2
3 addEvent(fm.elements[‘a1‘], ‘keyup‘, tabForWard);
4
5 addEvent(fm.elements[‘a2‘], ‘keyup‘, tabForWard);
6
7 addEvent(fm.elements[‘a3‘], ‘keyup‘, tabForWard);
8
9
10
11 function tabForward (evt) {
12
13 var e = evt || window.event;
14
15 var target = getTarget(evt);
16
17 //判断当前长度是否和指定长度一致
18
19 if (target.value.length == target.maxLength) {
20
21             //遍历所有字段
22
23 for (var i =0; i < fm.elements.length; i ++) {
24
25                 //找到当前字段
26
27 if (fm.elements[i] == target) {
28
29                   //就把焦点移入下一个
30
31 fm.elements[i + 1].focus();
32
33                     //中途返回
34
35 return;
36
37 }
38
39 }
40
41 }
42
43 }
44
45

二.选择框脚本

下面内容基于以下HTML代码:


 1 <body>
2
3 <form id="myForm" name="yourForm">
4
5 <select name="city">
6
7 <option value="上海v">上海t</option>
8
9 <option value="南京v">南京t</option>
10
11 <option value="杭州v">杭州t</option>
12
13 <option>无</option>
14
15 </select>
16
17 </form>

选择框是通过<select>和<option>元素创建的,除了通用的一些属性和方法外,HTMLSelectElement类型还提供了如下的属性和方法:

HTMLSelectElement对象























属性/方法

说明

add(new,rel)

插入新元素,并指定位置

multiple

布尔值,是否允许多项选择

options

<option>元素的HTMLColletion集合

remove(index)

移除给定位置的选项

selectedIndex

基于0的选中项的索引,如果没有选中项,则值为-1

size

选择框中可见的行数

在DOM中,每个<option>元素都有一个HTMLOptionElement对象,以便访问数据,这个对象有如下一些属性:

HTMLOptionElement对象




















属性

说明

index

当前选项在options集合中的索引

label

当前选项的标签

selected

布尔值,表示当前选项是否被选中

text

选项的文本

value

选项的值

var city =
fm.elements[‘city‘];      
             
             
//HTMLSelectElement

alert(city.options);        
             
             
         //HTMLOptionsCollection

alert(city.options[0]);    
             
             
         //HTMLOptionElement

alert(city.type);     
             
             
               
//select-one

PS:选择框里的type属性有可能是:select-one,也有可能是:select-multiple,这取决于HTML代码中有没有multiple属性。

 

标准DOM方法(不推荐):

alert(city.options[0].firstChild.nodeValue);  
       //上海t,获取text值,不推荐的做法

alert(city.options[0].getAttribute(‘value‘));   
       //上海v,获取value值,不推荐的做法

HTML DOM 方法(推荐):

alert(city.options[0].text);    
             
             
//上海t,获取text值,推荐

alert(city.options[0].value);  
             
             
//上海v,获取value值,推荐

PS:操作select时,最好使用HTML
DOM,因为所有浏览器兼容的很好。而如果使用标准DOM,会因为不同的浏览器导致不同的结果。

PS:当选项没有value值的时候,IE会返回空字符串,其他浏览器会返回text值。

 

选择选项

对于只能选择一项的选择框,使用selectedIndex属性最为简单。

addEvent(city, ‘change‘,
function () {

alert(this.selectedIndex);      
             
             
//得到当前选项的索引,从0开始

alert(this.options[this.selectedIndex].text);  
//得到当前选项的text值

alert(this.options[this.selectedIndex].value);
//得到当前选项的value值

});

PS:如果是多项选择,他始终返回的是第一个项。

 

city.selectedIndex = 1;  
             
             
       //设置selectedIndex可以定位到某个索引

通过option的属性(布尔值)selected,也可以设置某个索引,设置为true即可。

city.options[0].selected = true;     
             
       //设置第一个索引

而selected(作用在option对象上)和selectedIndex(作用在select对象上)在用途上最大的区别是:selected是返回的布尔值,所以一般用于判断上;而selectedIndex是数值,一般用于设置和获取。

addEvent(city, ‘change‘,
function () {

if (this.options[2].selected == true)
{           //判断第三个选项是否被选定

alert(‘选择正确!‘);

}

});

 

添加选项

如需动态的添加选项我们有两种方案:标准DOM和Option构造函数

使用标准DOM添加:

var option =
document.createElement(‘option‘);

option.appendChild(document.createTextNode(‘北京t‘));

option.setAttribute(‘value‘, ‘北京v‘)

city.appendChild(option);

使用Option构造函数添加:

  var option = new Option(‘北京t‘, ‘北京v‘);

  city.appendChild(option);     
             
             
//IE出现bug

使用add()方法来添加:

  var option = new Option(‘北京t‘, ‘北京v‘);

  city.add(option, 0);       
             
             
       //0,表示添加到第一位

PS:DOM规定,add()中两个参数是必须的,如果不确定索引,那么第二个参数设置null即可,即默认移入最后一个选项。但IE中规定第二个参数是可选的,所以设置null表示放入不存在的位置,导致失踪,为了兼容性,我们传递undefined即可兼容。

city.add(option, null);   
             
             
       //IE不显示了

city.add(option,
undefined);            
             
      
//
最佳兼容方案

 

移除选项

有三种方式可以移除某一个选项:DOM移除、remove()方法移除和null移除

city.removeChild(city.options[0]);
             
       //DOM移除

city.remove(0);     
             
             
             
//remove()
移除,推荐

city.options[0] = null;   
             
             
       //null移除

PS:当第一项移除后,下面的项会自动往上移动,所以不停的移除第一项,即可全部移除。

移动选项

如果有两个选择框,把第一个选择框里的第一项移到第二个选择框里,并且第一个选择框里的第一项被移除。

var city =
fm.elements[‘city‘];      
             
             
//第一个选择框

var info = fm.elements[‘info‘];     
             
       //第二个选择框

info.appendChild(city.options[0]);   
             
      
//
移动,自我删除

 

排列选项

选择框提供了一个index属性,可以得到当前选项的索引值,和selectedIndex的区别是,selectedIndex是选择框对象(select)的调用,index是选项对象(option)的调用。

var option1 = city.options[1];

city.insertBefore(option1,
city.options[option1.index - 1]);      
       //往下移动移位

单选按钮

通过checked属性来获取单选按钮的值。

for (var i = 0; i <
fm.sex.length; i ++) {     
             
//循环单选按钮

if (fm.sex[i].checked ==
true) {         
       //遍历每一个找出选中的那个

alert(fm.sex[i].value);          
             
//得到值

}

}

PS:除了checked属性之外,单选按钮还有一个defaultChecked属性,它获取的是原本的checked按钮对象,而不会因为checked的改变而改变。

if
(fm.sex[i].defaultChecked == true) {

alert(fm.sex[i].value);

}

 

复选按钮

通过checked属性来获取复选按钮的值。复选按钮也具有defaultChecked属性

var love = ‘‘;

for (var i = 0; i <
fm.love.length; i ++) {

if (fm.love[i].checked
== true) {

love
+= fm.love[i].value;

}

}

alert(love);

For my
lover and 

Thank
you ,Mr.Lee!

JavaScript表单处理(下),布布扣,bubuko.com

时间: 2024-10-22 15:51:33

JavaScript表单处理(下)的相关文章

JavaScript表单处理(上)

为了分担服务器处理表单的压力,JavaScript提供了一些解决方案,从而大大打破了处处依赖服务器的局面.  发文不易,转载请亲注明出处,谢谢! 一.表单介绍 在HTML中,表单是由<form>元素来表示的,而在JavaScript中,表单对应的则是HTMLFormElement类型.HTMLFormElement继承了HTMLElement,因此它拥有HTML元素具有的默认属性,并且还独有自己的属性和方法: HTMLFormElement属性和方法 属性或方法 说明 acceptCharse

JavaScript表单序列化的方法详解

本文介绍下,在javascript中实现表单序列化的方法,通过实例加深理解,有需要的朋友参考下吧. 在JavaScript中,可以利用表单字段的type属性,连同name和value属性一起实现对表单的序列. 首先,我们来了解下在表单提交期间,浏览器是怎样将数据发送给服务器的.对表单字段的名称和值进行URL编码,使用和号(&)分割.不发送禁用的表单字段.只发送勾选的复选框和单选按钮.不发送type为"reset"和"button"的按钮.多选择框中的每个选中

JavaScript表单验证和正则表达式

JavaScript表单验证 分为四类: 1.非空验证 常用于用户名等 2.相等验证 常用于验证两次输入的密码 3.范围验证 常用于年龄等 4.正则验证 用于手机号,邮箱号等 以下是实例: 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html

JavaScript - 表单提交前预览图片属性

即Preview image and its properties before upload 其实这东西网上到处都是,但并不完整. 正好我也遇到了这个问题,不仅仅是预览,还需要得到图片的属性. 于是东凑西凑整理出一个完整的版本,并根据个人的理解加上了一点点说明. (ps:感谢爆栈^^) 首先做一些准备工作,HTML方面主要是img和input标签的id:     <form>         <input type='file' id="imgFile"  />

JavaScript 表单、约束验证 DOM 属性

1.JavaScript 表单 1.1JavaScript 表单验证 HTML 表单验证可以通过 JavaScript 来完成. 以下实例代码用于判断表单字段(fname)值是否存在,如果存在,则弹出信息,否则阻止表单提交: function validateForm() { var x = document.forms["myForm"]["fname"].value; if (x == null || x == "") { alert(&qu

Javascript表单验证知识

Javascript表单编程: 一.表单元素的查找方式: 1.var oForm=document.getElementById("Form1"); 2.var oForm=document.forms[Form1]//通过name查找: 二.表单字段的共同特点: disabled:该属性用于指示一个表单控件是否可用: form属性:该属性返回包含字段的表单: blur():该方法导致表单字段失去焦点: focus():该方法导致表单字段获得焦点: blur事件:当表单字段失去焦点时,

JavaScript 表单编程

目标:主要是访问用户输入的表单数据,校验用户输入的正确性. 获取表单的引用: //方法一:将表单的ID作为方法的参数 var f1 = document.getElementById("f1"); //方法二:表单集合,得到第一个表单 var f2 = document.forms[0]; //方法三:得到名为fm的表单 var f3 = document.forms["fm"]; //方法四:简写 var f4 = document.fm 访问表单的元素: //获

JavaScript表单处理

JavaScript表单处理         一.表单介绍         属性或方法         action 服务器能够处理的字符集         length 表单中控件的数量         name 表单的名称         target 用于发送请求和接受响应的窗口名称         reset() 将所有表单重置         submit()  提交表单     获取表单<form>对象的方法有很多种,如下:         document.getElementB

JavaScript表单验证是否为中文

JavaScript表单验证是否为中文,判断一个输入量是否为中文,通过正则表达式实现. // 检查是否为中文 function isChn(str){ var reg = /^[u4E00-u9FA5]+$/; if(!reg.test(str)){m.mlyrx120.com return false; } return true; }