您现在的位置是:网站首页> 编程资料编程资料
用图片作为label,for属性IE下不起作用 _HTML/Xhtml_网页制作_
2023-11-12
245人已围观
简介 IE浏览器存在一个BUG,当你使用label的for属性达到点击label使对应的表单元素聚焦,label中的内容为图片时,IE浏览器下不起作用。
例如:
我们希望得到的效果是:点击“中国银行”,复选框会被选上(或者取消)。在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;iif(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;
}
}
}
}
}
}
复制代码
代码如下:我们希望得到的效果是:点击“中国银行”,复选框会被选上(或者取消)。在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
{
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;
}
}
}
}
}
}
相关内容
- 靠我们自己的力量把IE6推向灭亡_HTML/Xhtml_网页制作_
- html 块级标签与内联标签的区别 _HTML/Xhtml_网页制作_
- XHTML标签的嵌套规则分析_HTML/Xhtml_网页制作_
- 常见的HTML标记错误写法_HTML/Xhtml_网页制作_
- 让iframe透明的参数_HTML/Xhtml_网页制作_
- HTML 几种特别分割线特效 _HTML/Xhtml_网页制作_
- 熟手的html编写风格与原因分析_HTML/Xhtml_网页制作_
- HTML元素(标签)大全及使用介绍_HTML/Xhtml_网页制作_
- 编写email邮件的HTML页面原则小结_HTML/Xhtml_网页制作_
- 刀塔传奇智力型英雄灵魂石掉落获取详解_手机游戏_游戏攻略_
