成都网站建设设计

将想法与焦点和您一起共享

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://chengdu.cdxwcx.cn/article/djhepss.html">http://chengdu.cdxwcx.cn/article/djhepss.html</a> </div> </div> </div> <!--左边end--> <!--右边begin--> <div class="news_r"> <div class="news_t"><h2 class="h2">其他资讯</h2></div> <div class="news_ul3"> <ul> <li> <a href="/article/djoccgh.html"> <h3 class="h3">查看HTML文件代码:4种方法让你搞定</h3> </a> </li><li> <a href="/article/djoccds.html"> <h3 class="h3">windows传真和扫描怎么添加到桌面?windows传真想到</h3> </a> </li><li> <a href="/article/djoccig.html"> <h3 class="h3">MySQL支持一对多约束关系,实现数据表的规范约束及数据一致性</h3> </a> </li><li> <a href="/article/djocdhp.html"> <h3 class="h3">win11壁纸文件位置?windows壁纸是哪里下载</h3> </a> </li><li> <a href="/article/djoccij.html"> <h3 class="h3">日本高防ip服务器常用的防御措施有哪几种</h3> </a> </li> </ul> </div> </div> <!--右边end--> <div class="c_l"></div> </div> </div> <!--正文end--> <!--尾部begin--> <!--尾部begin--> <footer> <div class="f_bg"> <div class="wrap"> <div class="links"> <h2 class="h2">甜橘子解决方案<a href="/solution/" title="更多" class="more">更多+</a></h2> <ul> <li><a href="/solution/xiaochengxu.html" title="小程序定制解决方案">小程序定制解决方案</a></li> <li><a href="/solution/qiyewz.html" title="企业网站建设解决方案">企业网站建设解决方案</a></li> <li><a href="/solution/menhuwz.html" title="行业门户网站建设解决方案">行业门户网站建设解决方案</a></li> <li><a href="/solution/yingxiaowz.html" title="营销型网站建设解决方案">营销型网站建设解决方案</a></li> <li><a href="/solution/waimaowz.html" title="外贸网站建设解决方案">外贸网站建设解决方案</a></li> <li><a href="/solution/pingpaiwz.html" title="品牌形象网站建设解决方案">品牌形象网站建设解决方案</a></li> <li><a href="/solution/dianziwz.html" title="数码、电子产品网站建设解决方案">数码、电子产品网站建设解决方案</a></li> <li><a href="/solution/jituanwz.html" title="集团、上市企业网站建设解决方案">集团、上市企业网站建设解决方案</a></li> <li><a href="/solution/dichanwz.html" title="房地产、地产项目网站建设解决方案">房地产、地产项目网站建设解决方案</a></li> <li><a href="/solution/zhubaowz.html" title="珠宝高端奢侈品网站建设解决方案">珠宝高端奢侈品网站建设解决方案</a></li> </ul> </div> <div class="links w2"> <h2 class="h2">我们的实力<a href="/about/" title="更多" class="more">更多+</a></h2> <ul> <li>10年专业互联网服务经验</li> <li>成都高端建站设计团队</li> <li>资深行业分析策划</li> <li>B2C营销型网站建设者</li> <li>前沿视觉设计、研发能力</li> <li>前端代码深度符合SEO优化</li> <li>成都市高新技术企业证书</li> <li>具有完备的项目管理</li> <li>完善的售后服务体系</li> <li>深厚的网络运营经验</li> <li>时刻新技术研发能力</li> <li>16个网站系统软件著作权</li> </ul> </div> <div class="f_div2_r"> <h2 class="h2">关于甜橘子<a href="/about/" title="更多" class="more">更多+</a></h2> 甜橘子网站设计,为客户量身定制各类网站建设业务,包括企业型、电子商务型、行业门户型、品牌建立型等各类网站,实战经验丰富,成功案例众多。以客户利益为出发点,甜橘子网站制作为客户规划、定制符合企业需求、带有营销价值的建站方案,提供从网站前期定位分析策划到网站界面设计... </div> <div class="c_l"></div> </div> <div class="wrap"> <div class="f_div3"> <span class="l">成都网站制作案例©2020 甜橘子设计 版权所有 | <a href="http://chengdu.cdxwcx.cn" target="_blank">甜橘子网站设计</a><a href="http://chengdu.cdxwcx.cn" target="_blank">chengdu.cdxwcx.cn</a></span> <span class="r"><a href="https://beian.miit.gov.cn/" target="_blank" rel="nofollow">蜀ICP备11025516号</a></span> </div> </div> </div> </footer> <!--尾部end--> <script language="javascript" src="/Public/Home/js/foot.js"></script> <!--尾部end--> <!--侧边栏begin--> <div class="side"> <ul> <li id="qqonline_xbceo"><a href="tencent://message/?uin=631063699&Site=&Menu=yes"><i class="bgs1"></i>QQ咨询</a></li> <li class="shangqiao"><a href="tencent://message/?uin=532337155&Site=&Menu=yes" title="在线咨询"> <div><i class="bgs2"></i>在线咨询</div> </a></li> <li class="sideewm"><i class="bgs3"></i>官方微信 <div class="ewBox"></div> </li> <li class="sideetel"><i class="bgs4"></i>联系电话 <div class="telBox"> <dd class="bgs1"><span>座机</span><a href="tel:028-86922220" target="_blank">028-86922220</a></dd> <dd class="bgs2"><span>手机</span><a href="tel:13518219792" target="_blank">13518219792</a></dd> </div> </li> <li class="sidetop" onClick="goTop()" id="sidetop"><i class="bgs6"></i>返回顶部</li> </ul> </div> <script type="text/javascript"> $('.sideewm').hover(function(){ $('.ewBox').stop().fadeIn(); },function(){ $('.ewBox').stop().fadeOut(); }); $('.sideetel').hover(function(){ $('.telBox').stop().fadeIn(); },function(){ $('.telBox').stop().fadeOut(); }); $(".con_id 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); } }); </script> <!-- WPA start --> <!-- WPA end --> <!--侧边栏end--> </body> </html>