当ie7不认!important之后 [布局的解决办法]
程序员文章站
2024-02-28 20:57:52
在ie7之前,我们在布局时常用!important来解决ie和ff之间的差别; 但是在ie7出来之后,!important对ie7就不起作用了,而有些时候ie7的...
在ie7之前,我们在布局时常用!important来解决ie和ff之间的差别; 但是在ie7出来之后,!important对ie7就不起作用了,而有些时候ie7的解释方法又与ff和ie6不同;这时新的问题就出现了;用!important可以解决ie6但是解决不了ie7; 这样在不同的浏览器中看到的同一个网页的效果就不同了;
这是前天作布局时的一个问题;可以先看一下效果;http://www.zishu.cn/blogview.asp?logid=553
或者运行一下下边的代码也可以同样看到效果:
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>zishu.cn test</title>
<style>
body{ font-size:12px; line-height:1.8; font-family:verdana, "宋体", arial,sans; text-align:center; background:#fff; color:#666; margin:50px; padding:0; list-style:none; }
a:link,a:visited{color:#000099; text-decoration: underline;}
a:hover,a:active{color:#000;text-decoration: none;}
#zishu_test li{ float:left; width:14%;text-align:center; margin:0 auto; list-style:none }
#zishu_test li a{border-right:1px solid #fff;border-bottom:1px solid #fff; width:100px; height:110px; background:#fff;display:block; padding-top:10px; margin:auto}
#zishu_test li img{ width:75px; height:75px; display:block; text-align:center; margin:auto; background:#fff; padding:3px; border:1px solid #d8a18b;}
#zishu_test li span{display:none;}
#zishu_test li a:hover span{ margin-top:-10px;display:block; border-bottom:1px solid #666; border-right:1px solid #666; background:#fa9000; width:100px; color:#fff; position:absolute; }
* html #zishu_test li a:hover span {margin-left:-8px; } /* ie6 */
*+html #zishu_test li a:hover span {margin-left:-8px; }/* ie7*/
#zishu_test li a:hover{ border-right:1px solid #d8a18b;border-bottom:1px solid #d8a18b; width:100px; height:110px; background:#f5f5f5;display:block; padding-top:10px;}
</style>
</head>
<body>
<div id="zishu_test">
<ul>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>64d / 47 hits</span><img src="http://yy.kijiji.cn/img/p/10000009.jpg">pixu</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>24d / 35 hits</span><img src="http://yy.kijiji.cn/img/p/294343.jpg">秀才</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>66d / 87 hits</span><img src="http://yy.kijiji.cn/img/p/10000010.jpg">透露</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>40d / 34 hits</span><img src="http://yy.kijiji.cn/img/p/11709126.jpg">livid</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>47d / 56 hits</span><img src="http://yy.kijiji.cn/img/p/10000002.jpg">老孟</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>42d / 36hits</span><img src="http://yy.kijiji.cn/img/p/11695932.jpg">小玉</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>63d / 67 hits</span><img src="http://yy.kijiji.cn/img/p/10000025.jpg">pixu</a></li>
</ul>
</div>
</body>
</html>
在这个例子中,如果我把
程序代码
*+html #zishu_test li a:hover span {margin-left:-8px; }/* ie7*/
这行删除;那么在ie7中;就会有差别了;
为了解决这个问题,我看了;http://www.blueidea.com/tech/site/2006/3626.asp 里边的一种方法; 但是如果程序员和布局人不是同一个人的话;这样的方法很不好控制; 于是才有了下边的方法;
以下是代码;
程序代码
* html #zishu_test li a:hover span {margin-left:-8px; } /* ie6 */
*+html #zishu_test li a:hover span {margin-left:-8px; }/* ie7*/
这是针对ie6和ie7的两种方法;
“*+html”被ie7与ie5.01所使用,而区分ie7与ie5.01又有很简单的方法,便是important,把important写在前面,这样才能形成了单独针对ie7 hack的方法了。
比如:
*+html div.ie7 {
width:200px; !important;
width:100px;
}
这是前天作布局时的一个问题;可以先看一下效果;http://www.zishu.cn/blogview.asp?logid=553
或者运行一下下边的代码也可以同样看到效果:
复制代码 代码如下:
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>zishu.cn test</title>
<style>
body{ font-size:12px; line-height:1.8; font-family:verdana, "宋体", arial,sans; text-align:center; background:#fff; color:#666; margin:50px; padding:0; list-style:none; }
a:link,a:visited{color:#000099; text-decoration: underline;}
a:hover,a:active{color:#000;text-decoration: none;}
#zishu_test li{ float:left; width:14%;text-align:center; margin:0 auto; list-style:none }
#zishu_test li a{border-right:1px solid #fff;border-bottom:1px solid #fff; width:100px; height:110px; background:#fff;display:block; padding-top:10px; margin:auto}
#zishu_test li img{ width:75px; height:75px; display:block; text-align:center; margin:auto; background:#fff; padding:3px; border:1px solid #d8a18b;}
#zishu_test li span{display:none;}
#zishu_test li a:hover span{ margin-top:-10px;display:block; border-bottom:1px solid #666; border-right:1px solid #666; background:#fa9000; width:100px; color:#fff; position:absolute; }
* html #zishu_test li a:hover span {margin-left:-8px; } /* ie6 */
*+html #zishu_test li a:hover span {margin-left:-8px; }/* ie7*/
#zishu_test li a:hover{ border-right:1px solid #d8a18b;border-bottom:1px solid #d8a18b; width:100px; height:110px; background:#f5f5f5;display:block; padding-top:10px;}
</style>
</head>
<body>
<div id="zishu_test">
<ul>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>64d / 47 hits</span><img src="http://yy.kijiji.cn/img/p/10000009.jpg">pixu</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>24d / 35 hits</span><img src="http://yy.kijiji.cn/img/p/294343.jpg">秀才</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>66d / 87 hits</span><img src="http://yy.kijiji.cn/img/p/10000010.jpg">透露</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>40d / 34 hits</span><img src="http://yy.kijiji.cn/img/p/11709126.jpg">livid</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>47d / 56 hits</span><img src="http://yy.kijiji.cn/img/p/10000002.jpg">老孟</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>42d / 36hits</span><img src="http://yy.kijiji.cn/img/p/11695932.jpg">小玉</a></li>
<li><a href="http://yy.kijiji.cn/u/秀才"><span>63d / 67 hits</span><img src="http://yy.kijiji.cn/img/p/10000025.jpg">pixu</a></li>
</ul>
</div>
</body>
</html>
在这个例子中,如果我把
程序代码
*+html #zishu_test li a:hover span {margin-left:-8px; }/* ie7*/
这行删除;那么在ie7中;就会有差别了;
为了解决这个问题,我看了;http://www.blueidea.com/tech/site/2006/3626.asp 里边的一种方法; 但是如果程序员和布局人不是同一个人的话;这样的方法很不好控制; 于是才有了下边的方法;
以下是代码;
程序代码
复制代码 代码如下:
* html #zishu_test li a:hover span {margin-left:-8px; } /* ie6 */
*+html #zishu_test li a:hover span {margin-left:-8px; }/* ie7*/
这是针对ie6和ie7的两种方法;
“*+html”被ie7与ie5.01所使用,而区分ie7与ie5.01又有很简单的方法,便是important,把important写在前面,这样才能形成了单独针对ie7 hack的方法了。
比如:
*+html div.ie7 {
width:200px; !important;
width:100px;
}
上一篇: JAVA反射机制实例教程