IE7和IE8的CSS样式八大差异

你对IE7和IE8的CSS样式八大差异是否了解,这里和大家分享一下,IE7所设计的网页,在IE8上的呈现会有所出入,所幸拜IE7相容检视功能所赐,目前因使用IE8而导致版面错误的网站并不多。

当雄ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:028-86922220(备注:SSL证书合作)期待与您的合作!

IE7和IE8的CSS样式八大差异

InternetExplorer8预设是以CSS2.1为标准,并修正了许多InternetExplorer7的CSSBug,这意味着有一部份以往依据IE7所设计的网页,在IE8上的呈现会有所出入,所幸拜IE7相容检视功能所赐,目前因使用IE8而导致版面错误的网站并不多。但一值依赖IE7相容检视功能并非长久之计,尽早将网站修改为IE8相容才是长久之计,因为毕竟CSS是持续更新的,现在不改,日后大修的机会就更大。不幸的是,Microsoft官方并未提供关于IE7及IE8的CSS差异说明文件,顶多只是告诉我们IE8目前更趋近于CSS2.1而非CSS2.0,因此笔者在造访许多网站后,规类出8个最常见的差异供读者们参考。

1、起始座標位置

先天上,IE7与IE8在预设网页版面的起始位置就不同,以下面的代码来说,在IE7及IE8上启始的位置就有差异。

 
 
 
  1.  
  2. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
  3.  
  4.  
  5. title> </li> <li> head> </li> <li><body> </li> <li><divstyledivstyle="height:100px;width:200px;border:solid1pxblack"> </li> <li><div> </li> <li><ahrefahref="http://www.hinet.net">Hinet a> </li> <li> div> </li> <li> div> </li> <li> body> </li> <li> html> </li> <li> </li> </ol></pre><p>不过由于是整个偏移,对网页的影响相当小。</p><p><strong>2、DIV中的P</strong></p><p>下面的执行结果呈现了IE7及IE8在处理DIV中的P之差异性。<br /></p><pre> <ol> <li></li> <li> </li> <li>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> </li> <li><htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> </li> <li><head> </li> <li><title> title> </li> <li> head> </li> <li><body> </li> <li><divstyledivstyle="height:100px;width:200px;border:solid1pxblack"> </li> <li><div> </li> <li><p>TESTFont p> </li> <li> div> </li> <li> div> </li> <li> body> </li> <li> html> </li> <li> </li> </ol></pre><p>很明显的,IE8中对于DIV中的P预设位置与IE7不同,IE7是将margin-top预设为0px,排在最上方,,IE8却未预设margin-top,<br />解决方法是将margin-top加上。<br /></p><pre> <ol> <li></li> <li> </li> <li>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> </li> <li><htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> </li> <li><head> </li> <li><title> title> </li> <li> head> </li> <li><body> </li> <li><divstyledivstyle="height:100px;width:200px;border:solid1pxblack"> </li> <li><div> </li> <li><pstylepstyle="margin-top:0px">TESTFont p> </li> <li> div> </li> <li> div> </li> <li> body> </li> <li> html> </li> <li>(IE8Withmargin-top)  </li> <li> </li> </ol></pre><p> #p#<strong>3、负数margin</strong></p><p>许多网页设计师常常以负数的margin来定位HTML元素的位置,目的是让该元素与图形对齐,IE7及IE8对于负数的解释有蛮大的差异性。<br />程式4<br /></p><pre> <ol> <li></li> <li> </li> <li>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> </li> <li><htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> </li> <li><head> </li> <li><title> title> </li> <li> head> </li> <li><body> </li> <li><divstyledivstyle="height:100px;width:200px;border:solid1pxblack"> </li> <li><divstyledivstyle="background-color:Red;margin:-5px6px7px8px"> </li> <li><ahrefahref="http://www.hinet.net">Hinet a> </li> <li> div> </li> <li> div> </li> <li> body> </li> <li> html> </li> <li> </li> </ol></pre><p>由比较图可看出,IE7遭遇负数时,并不会移出DIV的范围,而IE8会,在笔者撰写本文之时,大多数的不相容IE8网页错误都源自于此。</p><p><strong>4、TableWithBorderStyle</strong></p><p>元素的Layout在每个浏览器上都会有些许差异的表现,下面的代码是一个在IE7及IE8上呈现相异的范例。Table<br /></p><pre> <ol> <li></li> <li> </li> <li>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> </li> <li><htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> </li> <li><head> </li> <li><title> title> </li> <li> head> </li> <li><body> </li> <li><tablestyletablestyle="border:double7pxgreen"> </li> <li><tr> </li> <li><tdstyletdstyle="border:double1pxgreen">a td> </li> <li><tdstyletdstyle="border:double1pxgreen">a td> </li> <li><tdstyletdstyle="border:double1pxgreen">a td> </li> <li> tr> </li> <li><tr> </li> <li><tdstyletdstyle="border:double1pxgreen">a td> </li> <li><tdstyletdstyle="border:double1pxgreen">a td> </li> <li><tdstyletdstyle="border:double1pxgreen">a td> </li> <li> tr> </li> <li><tr> </li> <li><tdstyletdstyle="border:double1pxgreen">a td> </li> <li><tdstyletdstyle="border:double1pxgreen">a td> </li> <li><tdstyletdstyle="border:double1pxgreen">a td> </li> <li> tr> </li> <li> table> </li> <li> body> </li> <li> html> </li> <li> </li> </ol></pre><p>很明显的,IE7的border宽度计算比IE8高,不过由于这是整体偏移,加上我们很少会设定太大的border宽度,影响程度几乎等于0。#p#</p><p><strong>5、bottom、top</strong></p><p>当使用绝对位置时,IE7与IE8会产生些许的偏移,这些偏移是整体性的,所以影响很小<br />例子:<br /></p><pre> <ol> <li></li> <li> </li> <li>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> </li> <li><htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> </li> <li><head> </li> <li><title> title> </li> <li> head> </li> <li><body> </li> <li><divstyledivstyle="height:100px;width:200px;border:solid1pxblack"> </li> <li><divstyledivstyle="background-color:Red;bottom:5px;top:5px;position:absolute;height:40px"> </li> <li>TEST  </li> <li> div> </li> <li> div> </li> <li> body> </li> <li> html> </li> <li> </li> </ol></pre><p>很难看出来吧,因为偏移很小,不过确实是偏移了。</p><p><strong>6、li+float</strong></p><p>UL、LI加上float,在IE7于IE8有相当大的差异,见:<br /></p><pre> <ol> <li></li> <li> </li> <li>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> </li> <li><htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> </li> <li><head> </li> <li><title> title> </li> <li> head> </li> <li><body> </li> <li><div> </li> <li><div> </li> <li><ul> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST1 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST2 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST3 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST4 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST5 li> </li> <li> ul> </li> <li> div> </li> <li> div> </li> <li> body> </li> <li> html> </li> <li> </li> </ol></pre><p>在IE7上,LI的项目符号被取消了,而在IE8上则正常显示,但却因为是float,所以后面的项目符号盖到前一项目了。修改为程式8的模样后<br />,两者就趋近相同了。</p><pre> <ol> <li></li> <li> </li> <li>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> </li> <li><htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> </li> <li><head> </li> <li><title> title> </li> <li> head> </li> <li><body> </li> <li><div> </li> <li><div> </li> <li><ulstyleulstyle="list-style-type:none"> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST1 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST2 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST3 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST4 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST5 li> </li> <li> ul> </li> <li> div> </li> <li> div> </li> <li> body> </li> <li> html> </li> <li> </li> </ol></pre><p>在尝试寻找CSS相异点时,许多网站都有这类问题,因为我们常用这种手法来处理页签类的显示。<br />PS:list-style-type在IE7时,只要li是float,就会被完全忽略。#p#</p><p><strong>7、div+heightwithulandimage</strong></p><p>当DIV设定了固定大小,而内容超出所定大小,然后后方跟着IMG时,在IE7及IE8会有相当大的差异。<br /></p><pre> <ol> <li></li> <li> </li> <li>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> </li> <li><htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> </li> <li><head> </li> <li><title> title> </li> <li> head> </li> <li><body> </li> <li><div> </li> <li><divstyledivstyle="width:300px;height:22px;margin-top:5px"> </li> <li><ulstyleulstyle="list-style-type:none"> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST1 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST2 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST3 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST4 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST5 li> </li> <li><listylelistyle="cursor:hand;float:left;"> </li> <li>TEST6 li> </li> <li> ul> </li> <li> div> </li> <li><ahrefahref="http://www.hinet.net>"> </li> <li><imgsrcimgsrc="21565.jpg"width="300px"height="200px"/> </li> <li> a> </li> <li> div> </li> <li> body> </li> <li> html> </li> <li> </li> </ol></pre><p>很明显的,IE7会尊重DIV所制定的大小来安排后面的IMG位置,所以在图14上看不出有何问题,但是在IE8里,当内容超出制定大小时,<br />IMG位置会顺移开,所以就造成了此问题。在实务上,这算是相当常见的相容性错误。<br />解决方法很简单,将要被盖住的那个LI移掉就好了,这本来就是错误的设计。</p><p><strong>8、p的子控件对齐</strong></p><p>有些网页设计师习惯使用P加上子控件来描绘单行输入+按纽的样式,这些网页在IE8上会有或许的差异,如果里面使用的IMG太多,<br />差异就会大到很难忽视。<br /></p><pre> <ol> <li></li> <li> </li> <li>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> </li> <li><htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> </li> <li><head> </li> <li><title> title> </li> <li> head> </li> <li><body> </li> <li><p> </li> <li><inputtypeinputtype="text"/> </li> <li><imgsrcimgsrc="add2.png"height="16px"width="16px"/> </li> <li> p> </li> <li> body> </li> <li> html> </li> <li> </li> </ol></pre><p>很明显,IE7会对IMG置中于P,但IE8不会。这类问题很难解决,需要透过CSS判断IE版本来提供不同的CSS,让两者趋近相同。<br /></p><pre> <ol> <li></li> <li> </li> <li>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> </li> <li><htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"> </li> <li><head> </li> <li><title> title> </li> <li> 浅析<em>CSS</em>在<em>IE</em>6、<em>IE7</em>、<em>IE8</em>中<em>的</em>兼容<em>差异</em> 本文向大家介绍一下CSS在IE6、IE7、IE8中的兼容差异解析,关于浏览器的最离奇的统计结果之一就是InternetExplorer版本IE6,IE7和IE8共存。 <p>2010-08-18 10:37:16</p> IE6 IE7 IE8</li> </ol></pre> <br> 文章标题:IE7和IE8的CSS样式八大差异 <br> 分享网址:<a href="http://www.turtgq.com/article/djhepss.html">http://www.turtgq.com/article/djhepss.html</a> </div> </div> <div class="other container"> <h3>其他资讯</h3> <ul> <li><a href="/article/djhicgh.html">文件借助vmlinux实现跨平台共享文件(vmlinux共享)</a></li><li><a href="/article/djhicgi.html">怎么更改电脑账户同步?windows同步机制</a></li><li><a href="/article/djhicge.html">MSSQL中使用循环实现表行遍历(mssql 循环表行)</a></li><li><a href="/article/djhicsj.html">DB2数据类型与DB2内置数据类型</a></li><li><a href="/article/djhicgg.html">SmittyLinux:轻松愉快地体验Linux操作系统(ittylinux)</a></li> </ul> </div> <div class="foot_line"></div> <footer> <div class="foot container"> <ul> <li> <b>基础服务</b> <a href="https://www.cdcxhl.com/bastion/" target="_blank">堡垒主机</a><a href="https://www.cdxwcx.com/host/hk/" target="_blank">香港空间</a><a href="https://www.cdxwcx.com/host/javajsp/" target="_blank">java主机</a><a href="https://www.cdcxhl.com/zuyong/" target="_blank">成都主机租赁</a><a href="https://www.cdxwcx.com/domain/" target="_blank">域名申请</a><a href="https://www.cdxwcx.com/host/javajsp/" target="_blank">jsp虚拟主机</a> </li> <li> <b>服务器托管</b> <a href="https://www.cdxwcx.com/jifang/meishan.html" target="_blank">眉山服务器托管</a><a href="https://www.cdcxhl.com/idc/ershu.html" target="_blank">二枢服务器托管</a><a href="https://www.cdcxhl.com/jigui/" target="_blank">服务器机柜租赁</a><a href="https://www.cdcxhl.com/idc/cqstsanx.html" target="_blank">重庆水土三线托管</a><a href="https://www.cdcxhl.com/jigui/" target="_blank">服务器托管机柜</a><a href="https://www.cdcxhl.com/tuoguan/yidong/" target="_blank">移动服务器托管</a> </li> <li> <b>网络营销</b> <a href="https://www.cdcxhl.com/hangyead/" target="_blank">一元广告投放</a><a href="http://seo.cdkjz.cn/" target="_blank">成都seo优化</a><a href="http://www.kswjz.com/" target="_blank">网站优化推广</a><a href="https://www.cdcxhl.com/seo/chengdu.html" target="_blank">成都网站优化</a><a href="http://chengdu.cdcxhl.cn/seo/" target="_blank">网站优化排名推广</a><a href="http://6mz.cn/index.html" target="_blank">成都网站推广</a> </li> <li> <b>其他分站</b> <a href="https://www.cdcxhl.com/seo/emeishan.html" target="_blank">峨眉山网站优化</a><a href="http://www.cqcxhl.com/" target="_blank">重庆网站制作</a><a href="https://www.cdcxhl.com/city/ziyang.html" target="_blank">资阳网站建设</a><a href="https://www.cdcxhl.com/zuo/dazhou.html" target="_blank">达州做网站</a><a href="https://www.cdcxhl.com/zhizuo/mianyang.html" target="_blank">绵阳网站制作</a><a href="https://www.cdcxhl.com/zhizuo/yaan.html" target="_blank">雅安网站制作</a> </li> <li> <b>企业服务</b> <a href="https://www.cdcxhl.com/link/" target="_blank">链接买卖</a><a href="https://www.cdcxhl.com/ruanwen/" target="_blank">软文营销</a><a href="https://www.cdcxhl.com/service/wenwangwen.html" target="_blank">网络文化经营许可证</a><a href="https://www.cdcxhl.com/ruanwen/yingxiao/" target="_blank">软文平台</a><a href="https://www.cdcxhl.com/service/icpxuke.html" target="_blank">互联网信息经营许可证</a><a href="https://www.cdcxhl.com/mianfei/jianzhan/" target="_blank">免费建站</a> </li> <li> <b>网站设计</b> <a href="http://www.cdkjz.cn/fangan/led/" target="_blank">LED网站设计方案</a><a href="http://www.abwzjs.com/" target="_blank">阿坝网站设计</a><a href="https://www.cdcxhl.com/sheji/chengdu.html" target="_blank">四川成都网站设计</a><a href="http://chengdu.cdcxhl.com/" target="_blank">成都网站设计</a><a href="http://www.kswcd.com/" target="_blank">企业网站设计</a><a href="http://www.ybwzjz.com/" target="_blank">宜宾网站设计</a> </li> <li> <b> </b> <p class="linkbtom_p1"><img src="../img/foot1.png" alt="">免费咨询电话</p> <p class="linkbtom_p4">028-86922220</p> <p class="linkbtom_p2"><img src="../img/foot2.png" alt="">631063699@qq.com</p> <p class="linkbtom_p3"><img src="../img/foot3.png" alt="">成都市青羊区太升南路288号</p> <a target="_blank" href="" class="help">寻求帮助</a> </li> </ul> </div> <div class="link container"> <div class="linkl fl">友情链接</div> <div class="linkr fl"> <ul> <li><a href="http://www.cxjianzhan.cn/" target="_blank">诚信建站</a></li> <li><a href="http://www.kswcd.com/" target="_blank">定制网站建设</a></li> <li><a href="http://www.cqcxhl.com/" target="_blank">重庆网站制作</a></li> <li><a href="http://www.cdkjz.cn/" target="_blank">网站设计</a></li> <li><a href="http://www.cxjianzhan.com/" target="_blank">网站建设公司</a></li> <li><a href="http://www.bzwzjz.com/" target="_blank">网页设计</a></li> <li><a href="http://chengdu.cdweb.net/" target="_blank">网站建设</a></li> <li><a href="https://www.xwcx.net/" target="_blank">成都机柜租用</a></li> <li><a href="http://www.kswsj.cn/" target="_blank">网站营销推广</a></li> <li><a href="https://www.xwcx.net/" target="_blank">成都托管服务器</a></li> <li><a href="http://www.cdfuwuqi.com/" target="_blank">成都托管服务器</a></li> <li><a href="http://www.cdweb.net/" target="_blank">响应式网站</a></li> <li><a href="http://www.cdxwcx.cn/" target="_blank">成都做网站</a></li> <li><a href="http://www.cdxwcx.cn/tuoguan/" target="_blank">托管服务器</a></li> <li><a href="http://www.idckuai.cn/" target="_blank">域名注册</a></li> <li><a href="http://chengdu.cdxwcx.cn/" target="_blank">网站设计</a></li> <li><a href="https://www.scvps.cn/" target="_blank">网站空间</a></li> <li><a href="http://www.dmvi.cn/" target="_blank">广告设计</a></li> <li><a href="https://www.cdcxhl.com/cqtuoguan.html" target="_blank">重庆服务器托管</a></li> <li><a href="https://www.scvps.cn/" target="_blank">服务器租赁</a></li> <li><a href="http://www.cxhljz.com/" target="_blank">成都网站建设</a></li> <li><a href="https://www.cdcxhl.com/" target="_blank">网站建设</a></li> <li><a href="https://www.xwcx.net/" target="_blank">vps服务器</a></li> <li><a href="http://www.cdfuwuqi.com/" target="_blank">云服务器</a></li> <li><a href="http://chengdu.cdcxhl.com/" target="_blank">营销网站建设</a></li> <li><a href="http://www.cdhuace.com/" target="_blank">成都广告公司</a></li> </ul> </div> </div> <div class="footb">成都鸿航鸿康科技有限公司 | <a href="http://www.turtgq.com/" target="_blank"><strong>网站建设</strong></a><span style="color:;">  </span><span style="color:;"><strong><a href="http://www.turtgq.com/wangzhan/" target="_blank">网站设计制作</a></strong></span><span style="color:;"> <strong><a href="http://www.turtgq.com/wangzhan/" target="_blank">网站开发</a></strong><strong> </strong></span>版权所有Copyright2019-2020 | © <span></span></div> </footer> <div class="footm-line"></div> <div class="footm"> <ul> <li> <a href="../"><img src="../img/footm1.png" alt=""><p>首页</p></a> </li> <li> <a href="tel:028-86922220"><img src="../img/footm2.png" alt=""><p>电话</p></a> </li> <li> <a href="http://wpa.qq.com/msgrd?v=3&uin=631063699&site=qq&menu=yes" target="_blank"><img src="../img/footm3.png" alt=""><p>咨询</p></a> </li> <li> <a href="../about/contact.html"><img src="../img/footm4.png" alt=""><p>地图</p></a> </li> </ul> </div> </body> </html> <script> $(".cont img").each(function(){ var src = $(this).attr("src"); //获取图片地址 var str=new RegExp("http"); var result=str.test(src); if(result==false){ var url = "https://www.cdcxhl.com"+src; //绝对路径 $(this).attr("src",url); } }); window.onload=function(){ document.oncontextmenu=function(){ return false; } } </script>