热门关键字:
jquery > jquery教程 > jquery教程 > 为什么IE6下容器的宽度和FF解释不同呢

为什么IE6下容器的宽度和FF解释不同呢

355
作者:管理员
发布时间:2021/1/22 18:52:15
评论数:0
转载请自觉注明原文:http://www.jq-school.com/Show.aspx?id=3417
<?xml version=”1.0″ encoding=”gb2312″?>
<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Strict//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd“>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″ />
<style type=”text/css”>
<!–
div {
cursor:pointer;
width:200px;
height:200px;
border:10px solid red
}
–>
</style>
<div ōnclick=”alert(this.offsetWidth)”>让FireFox与IE兼容</div>


问题的差别在于容器的整体宽度有没有将边框(border)的宽度算在其内,这里IE6解释为200PX ,而FF则解释为220PX,那究竟是怎么导致的问题呢?大家把容器顶部的xml去掉就会发现原来问题出在这,顶部的申明触发了IE的qurks mode,关于qurks mode、standards mode的相关知识,请参考相关资料。


IE6,IE7,FF


IE7.0出来了,对CSS的支持又有新问题。浏览器多了,网Bpx; /*For IE7 & IE6*/
_height:20px; /*For IE6*/


注意顺序。


这样也属于CSS HACK,不过没有上面这样简洁。


#example { color: #333; } /* Moz */
* html #example { color: #666; } /* IE6 */
*+html #example { color: #999; } /* IE7 */


第二种,是使用IE专用的条件注释


<!–其他浏览器 –>
<link rel=”stylesheet” type=”text/css” href=”css.css” />


<!–[if IE 7]>
<!– 适合于IE7 –>
<link rel=”stylesheet” type=”text/css” href=”ie7.css” />
<![endif]–>


<!–[if lte IE 6]>
<!– 适合于IE6及一下 –>
<link rel=”stylesheet” type=”text/css” href=”ie.css” />
<![endif]–>


第三种,css filter的办法,以下为经典从国外网站翻译过来的。.


新建一个css样式如下:


#item {
width: 200px;
height: 200px;
background: red;
}


新建一个div,并使用前面定义的css的样式:


<div id=”item”>some text here</div>


在body表现这里加入lang属性,中文为zh:


<body lang=”en”>


现在对div元素再定义一个样式:


*:lang(en) #item{
background:green !important;
}


这样做是为了用!important覆盖原来的css样式,由于:lang选择器ie7.0并不支持,所以对这句话不会有任何作用,于是也达到了 ie6.0下同样的效果,但是很不幸地的是,safari同样不支持此属性,所以需要加入以下css样式:


#item:empty {
background: green !important
}




如果您觉得本文的内容对您的学习有所帮助:支付鼓励



关键字:jQuery
友荐云推荐