码迷,mamicode.com
首页 > 其他好文 > 详细

bug:在label中包含img,在IE中点击图片的时候,radio没有被选中,别的浏览器可以

时间:2014-08-14 23:06:50      阅读:256      评论:0      收藏:0      [点我收藏+]

标签:des   style   blog   color   os   io   for   ar   

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="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;
} } } } } }

显然第一种方式更为简单,至于为什么,等我调查一下…………

 

bug:在label中包含img,在IE中点击图片的时候,radio没有被选中,别的浏览器可以,布布扣,bubuko.com

bug:在label中包含img,在IE中点击图片的时候,radio没有被选中,别的浏览器可以

标签:des   style   blog   color   os   io   for   ar   

原文地址:http://www.cnblogs.com/bjchenxn/p/3913281.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!