当前位置: 首页 > 图文教程 > 网络编程 > Javascript > IE中checkbox在刷新后初始化的问题

Javascript
javascript innerText和innerHtml应用
图像替换新技术 状态域方法
JavaScript 判断判断某个对象是Object还是一个Array
Extjs 几个方法的讨论
JavaScript 学习笔记(十五)
javascript 匿名函数的理解(透彻版)
Jquery 常用方法经典总结
jquery 批量上传图片实现代码
javascript中的array数组使用技巧
详细讲解JS节点知识
javascript让setInteval里的函数参数中的this指向特定的对象
javaScript 关闭浏览器 (不弹出提示框)
对字符串进行HTML编码和解码的JavaScript函数
javascript 三种编解码方式
js左侧多级菜单动态的解决方案
JavaScript 学习笔记(十六) js事件
JavaScript面向对象之静态与非静态类
javascript两段代码,两个小技巧
js中鼠标滚轮事件详解(firefox多浏览器)
js实现的仿Photoshop鼠标滚轮控制输入框取值(修正兼容Chrome)

Javascript 中的 IE中checkbox在刷新后初始化的问题


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-02-27   浏览: 212 ::
收藏到网摘: n/a

在项目中有一个需求,要求页面中的checkbox在页面刷新或后退时都要重新初始化,即处于未选中的状态,不保存之前的状态。 初一看这个功能很简单,一个checkbox,加一段脚本,把这个checkbox的checked属性设为false。
复制代码 代码如下:

<input type="checkbox" id="chk_UnInital" name="chk_UnInital" />
<script>document.getElementById("chk_UnInital").checked=false;</script>

这段代码在firefox等其它浏览器中都能实现这个需求,维独在IE中死活不行,每次把勾勾上,无论是刷新还是后退,这个勾都是勾上的。
难道是在IE下这段代码没工作?
验证一下,在这段脚本前后各加一个alert,发现在执行这checked=false之前和之后这个checkbox都是未选中的,当把警告框确定后,这个勾反而出现了!
这说明在后面的页面加载顺序中,某个事件又把这个checkbox设为true了,先试着在页面onload里再执行这段脚本
复制代码 代码如下:

<script>
window.onload=function(){
  alert("before");
  document.getElementById("chk_UnInital").checked=false;
}
</script>

果然发现在执行alert("before");时这个勾是选中的,这说明在onload事件之前这个勾就被浏览器自动选上了,具体是什么原因就涉及到IE内部的机制了。
将这个function注册在onload事件里,到这里这个需求就实现了。
然而onload是在页面所有的元素都加载完后才会执行,在本地测试的时候有一个请求返回很慢,从而使onload事件迟迟不能执行,这是我们不愿意看到的。
后来发现网站上另一处checkbox在页面刷新时不会保存之前的状态,经过仔细对比之后发现这个input多了一个checked=""属性:
<input type="checkbox" id="chk_Inital" name="chk_Inital" checked="" />
有了这个属性后,事件不用放在onload里也能起作用了
这是什么原因呢?
接着做以下试验:
复制代码 代码如下:

<input type="checkbox" id="chk_UnInital" name="chk_UnInital" />
<label for="chk_UnInital">This checkbox can't be Inital</label>
<br>
<input type="checkbox" id="chk_Inital" name="chk_Inital" checked=""/>
<label for="chk_Inital">This checkbox can be inital</label>
<br>
<script>
//window.onload=function(){
var chks=document.getElementsByTagName("input");
for(var i=0,l=chks.length;i<l;i++){
  alert(chks[i].id);
  chks[i].checked=false;
}
//}
</script>

为了便于叙述,我们这里将上面这段脚本的执行时间称为t1,window.onload的执行时间称为t3,这之间的执行时间称为t2
通过加入alert后,对比发现:
      chk_UnInital  chk_Inital
脚本放在script块中执行:
t1之前    未选中      选中
t1之后    选中      未选中
下面是放在onload中执行:
t3之前    选中       选中
t3之后    未选中      未选中
发现加checked=""后在t1之前即为选中状态,然后被t1置为unchecked。
总结:
方案一:在onload事件里处理
方案二:加上checked属性

[Ctrl+A 全选 提示:你可先修改部分代码,再按运行]