用图片作为label,for属性IE下不起作用
用图片作为label,for属性IE下不起作用
发布时间:2016-12-27 来源:查字典编辑
摘要:例如:我们希望得到的效果是:点击“中国银行”,复选框会被选上(或者取消)。在FireFox,CHROME等浏览器下是...

例如:

<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;

}

}

}

}

}

}

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新XHTML学习
热门XHTML学习
网页设计子分类