用图片作为label,for属性IE下不起作用


例如:

复制代码
代码如下:

<input type="checkbox" id="a"><label for="a"><img src="..."></label>

我们希望得到的效果是:点击“中国银行”,复选框会被选上(或者取消)。在FireFox,CHROME等浏览器下是没有问题的,但是IE浏览器却不吃这套。

解决的办法是使用JS:

复制代码
代码如下:

window.onload = function(){
if(document.all && navigator.appVersion.indexOf("MSIE")>-1 && navigator.appVersion.indexOf("Windows")>-1)
{
var a = document.getElementsByTagName("label");
for(var i=0,j=a.length;i<j;i++){
if(a[i].hasChildNodes && a[i].childNodes.item(0).tagName == "IMG")
{
a[i].childNodes.item(0).forid = a[i].htmlFor;
a[i].childNodes.item(0).onclick = function(){
var e = document.getElementById(this.forid);
switch(e.type){
case "radio": e.checked|=1;break;
case "checkbox": e.checked=!e.checked;break;
case "text": case "password": case "textarea": e.focus(); break;
}
}
}
}
}
}



相关阅读:
通过JAVAScript实现页面自适应
巧妙在IIS中配置PHP调试环境(一)
Linux后台进程(cron和crontab)
Fedora系统下检测声卡的命令
Linux oracle 9i图文安装教程六 完结篇
Windows7系统提示更换笔记本电池
突破winxp sp2/win2003 sp2超强弹窗代码
SQL SERVER的数据类型
动态生成页面元素的代码
PHP 图片上传代码
Zend framework处理一个http请求的流程分析
javascript 进阶篇3 Ajax 、JSON、 Prototype介绍
Oracle数据库处理时间的技巧
对hao123进行重构
快速导航

Copyright © 2016 phpStudy |