// 用户点击重置按钮时,表单会被初始化;
// 虽然这个按钮还得以保留,但目前Web已经很少去使用了;因为用户填好信息后,不小心点击了重置就会全部清空,用户体验极差;
// 有两种方法调用reset事件:第一个就是直接type="reset"即可;第二个就是使用fm.reset()方法调用;
<input type="reset" value="重置" /> // 不需要JS代码即可实现;
addEvent(document,'click',function(){
fm.reset(); // 使用JS方法实现重置;
});
// 利用focus事件修改文本框的背景色;
// 利用change事件在用户输入非数值字符时再次修改背景色;
var bextbox = document.forms[0].elements[0];
EventUtil.addHandler(textbox,'focus',function(evt){
evt = EventUtil.getEvent(evt);
var target = EventUtil.getTarget(evt);
if(target.style.backgroundColor != 'red'){
target.style.backgroundColor = 'yellow'; // 选中状态时文本框的背景是黄色;
}
});
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 = '';
}
});
// 使用select()方法,可以将文本框里的内容选中,并将焦点设置到文本框中;
textField.select(); // 在文本框获得焦点时选择其所有文本;
// 选取部分文本
// 在使用文本框内容的时候,我们有时要直接选定部分文本,这个行为还没有标准;
// 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才可以这么写;
});
// 获得选择的文本
// Firefox提供了两个属性:selectionStart和selectionEnd;
addEvent(textField,'select',function(){
alert(this.value.substring(this.selectionStart,this.selectionEnd));
});
// IE8以下,提供了另一个方案:selection对象,属于document;
// 这个对象保存着用户在整个文档范围内选择的文本信息;
// 兼容函数
function getSelecText(text){
if(typeof text.selectioinStart =='number'){ // 非IE;
return text.value.substring(text.selectionStart,text.selectionEnd);
}else if(document.selection){ // IE;
return document.selection.createRange().text; // 获取IE选择的文本;
}
}
// PS:存在问题:IE在触发select事件的时候,在选择一个字符后立即触发,而其他浏览器是选择想要的字符后释放鼠标键时再触发;
// 所以使用alert()的话,导致跨浏览器的不兼容;
// 所以我们可以通过将得到的选择文本赋值给别的对象;
addEvent(textField,'select',function(){
// alert(getSelecText(this)); // 导致用户行为结果不一致;
document.getElementById('box').innerHTML = getSelecText(this);
})
// 为了使文本框输入指定的字符,我们必须对输入进文本框的字符进行验证;
addEvent(areaField,'keypress',function(evt){
var e = evt || window.event;
var charCode = getCharCode(evt); // 得到字符编码;
if(!/\d/.test(String.formCharCode(charCode)) && charCode>9 && !e.ctrlKey){
preDef(evt); // 条件阻止默认;
}
});
// PS:前半段条件判断只有数字才可以输入,导致常规按键,比如光标键/退格键/删除键等无法使用;
// 部分浏览器比如Firefox,需要解放这些键,而非字符触发的编码均为0;
// 在Safari3之前的浏览器,也会被阻止,而它对应的字符编码全部为8,所以最后加上charCode>9的判断;
// 确保用户没有按下ctrl键;
// 阻止文本框裁剪/复制和粘贴;
事件名 说明
copy 在发生复制操作时触发;
cut 在发生裁剪操作时触发;
paste 在发生粘贴操作时触发;
beforecopy 在发生复制操作时触发;
beforecut 在发生裁剪操作时触发;
beforepaste 在发生粘贴操作时触发;
// 如果我们想要禁用裁剪/复制/粘贴,那么可以阻止默认行为即可;
addEvent(areaField,'cut',function(evt){
preDef(evt);
});
addEvent(areaField,'copy',function(evt){
preDef(evt);
});
addEvent(areaField,'paste',function(evt){
preDef(evt);
});
// 最后一个影响输入的因素,就是:输入法;
// 中文输入法,它的原理是在输入法面板上先储存文本,按下回车就写入英文文本,按下空格就写入中文文本;
// 解决方案:通过CSS来禁止调出输入法;
style='ime-mode:disabled'; // CSS直接编写;
areaField.style.imeMode='disabled'; // 在JS中设置;
// PS:Chrome无法禁止输入法调出,所以,最后使用正则验证已输入的文本;
addEvent(areaField,'keyup',function(evt){
this.value = this.value.replace(/[^\d]/g,''); // 把非数字都替换成空;
});
// 为了增加表单字段的易用性,很多字段在满足一定条件时(比如长度),就会自动切换到下一个字段上继续填写;
<input type='text' name='user1' maxlength='1'/> // 只能写1个;
<input type='text' name='user2' maxlength='2'/>
<input type='text' name='user3' maxlength='3'/>
function tabForward(evt){
var e = evt || window.event;
var target = getTarget(evt);
// 判断当前长度是否和指定长度一致;
if(target.value.length == target.maxLength){
// 遍历所有字段;
for(var i=0; i<fm.elements.length; i++){
// 找到当前字段;
if(fm.elements[i]==target){
// 就把焦点移入下一个字段;
if(fm.elements[i+1]){
fm.elements[i+1].focus();
}
// 中途返回;
return;
}
}
}
}
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属性; alert(city.options[0].text); // 上海text,获取text值; alert(city.options[0].value); // 上海value,获取value值; // PS:操作select时,最好使用HTMLDOM,以为浏览器兼容性比较好; // 如果使用标准DOM,会因为不同的浏览器导致不同的结果; // PS:当选项没有value值的时候,IE会返回空字符串,其他浏览器会返回text值;
// 有三种方式可以移除某一个选项:DOM移除/remove()方法移除和null移除; city.removeChild(city.option[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]); // 移动,并在第一个选择框中删除;
// 通过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属性来获取复选按钮的值,
var love = '';
for(var i=0; i<fm.love.length; i++){
if(fm.love[i].checked == true){
love += fm.love[i].value;
}
}
alert(love);
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有