首页 > 代码库 > bug:在label中包含img,在IE中点击图片的时候,radio没有被选中,别的浏览器可以
bug:在label中包含img,在IE中点击图片的时候,radio没有被选中,别的浏览器可以
bug:在label中包含img,在IE中点击图片的时候,按钮没有被选中,别的浏览器可以
代码如下:
1 <td class="left">2 <input type="radio" name="sex" id="boy"/>3 <label for="boy" disabled=""><img src="images/boy.jpg"/>男</label>4 <input type="radio" name="sex" id="girl"/>5 <label for="girl" disabled=""><img src="images/girl.jpg"/>女</label>6 </td>
三种解决方式:
第一种html:
在img中添加一个disabled=""就可以解决问题
<label for="girl"><img src="images/girl.jpg" disabled=""/>女</label>
第二种css:
在图片上覆盖一个容器,容器本身透明显示
<input type="radio" name="radio" id="a" /><label for="a"><img src="http://www.mamicode.com/xxx.jpg" /><span></span></label>
将其中SPAN的属性设定有底色并且透明,SPAN覆盖到IMG上,并保持和图片同样的尺寸。
display:block;
width:100px;
height:100px;
background:url(xxx.png) no-repeat 0 0;
position:absolute;
left:0;
top:0;
第三种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;} } } } } }
显然第一种方式更为简单,至于为什么,等我调查一下…………
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。