资源描述:
《如何兼容ie7和ie8-divcss教程》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、CSS兼容问题已经是CSS网页布局技术中的重要组成部分,也让广大的CSSer大为头疼,虽然westphp.com介绍过不少相关的知识与技巧,但是随着IE8的越来越广泛的安装应用,对IE7和IE8的兼容问题,也颇受关注。 在以前的文章中westphp.com向大家说明,IE8会是福音还是又一个光环据称全面兼容标准。 今天向大家介绍如何解决IE7和IE8的兼容性问题。 微软在IE8提供三种解析页面的模式 IE8StandardModes:默认的最标准的模式,严格按照W3C相关规定 IE7StandardsModes:IE7现在用的解析网页的模式,开起机关是在
中加入<
2、metahttp-equiv="X-UA-Compatible"content="IE=7"> QuirksModes:IE5用的解析网页的模式,开起机关是删除HTML顶部的DOCTYPE声明 注意:不同模式间的网页在IE8中可以互相frame,因此因不会模式下的DOM和CSS渲染不一样,所以会引发很多问题,务必注意如果你的页面对IE7兼容没有问题,又不想大量修改现有代码,同时又能在IE8中正常使用,微软声称,开发商仅需要在目前兼容IE7的网站上添加一行代码即可解决问题,此代码如下:
3、IE8最新csshack: "9" 例:"margin:0pxauto9;".这里的"9"可以区别所有IE和FireFox. "*" IE6、IE7可以识别.IE8、FireFox不能. "_" IE6可以识别"_",IE7、IE8、FireFox不能.CSS对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理方法并整理了一下.对于web2.0的过度,请尽量用xhtml格式写代码,而且DOCTYPE影响CSS处理,作为W3C的标准,一定要加DOCTYPE声名.?CSS技巧1.div的垂直居中问
4、题vertical-align:middle;将行距增加到和整个DIV一样高line-height:200px;然后插入文字,就垂直居中了。缺点是要控制内容不要换行?2.margin加倍的问题?设置为float的div在ie下设置的margin会加倍。这是一个ie6都存在的bug。解决方案是在这个div里面加上display:inline;?例如:?<#divid=”imfloat”>?相应的css为?#IamFloat{?float:left;?margin:5px;/*IE下理解为10px*/?display:inline;/*IE下再理解为5px*/}?3.浮动ie产生的双倍距
5、离?#box{float:left;width:100px;margin:000100px;//这种情况之下IE会产生200px的距离display:inline;//使浮动忽略}?这里细说一下block与inline两个元素:block元素的特点是,总是在新行上开始,高度,宽度,行高,边距都可以控制(块元素);Inline元素的特点是,和其他元素在同一行上,不可控制(内嵌元素);?#box{display:block;//可以为内嵌元素模拟为块元素display:inline;//实现同一行排列的效果diplay:table;?4IE与宽度和高度的问题IE不认得min-这个定义,但
6、实际上它把正常的width和height当作有min的情况来使。这样问题就大了,如果只用宽度和高度,正常的浏览器里这两个值就不会变,如果只用min-width和min-height的话,IE下面根本等于没有设置宽度和高度。?比如要设置背景图片,这个宽度是比较重要的。要解决这个问题,可以这样:?#box{width:80px;height:35px;}html>body#box{width:auto;height:auto;min-width:80px;min-height:35px;}?5.页面的最小宽度?min-width是个非常方便的CSS命令,它可以指定元素最小也不能小于某个宽
7、度,这样就能保证排版一直正确。但IE不认得这个,而它实际上把width当做最小宽度来使。为了让这一命令在IE上也能用,可以把一个
放到标签下,然后为div指定一个类,然后CSS这样设计:?#container{min-width:600px;width:expression(document.body.clientWidth<600?"600px":"auto");}?第一个min-width是正常的;但第2行的width使用了Java
当前文档最多预览五页,下载文档查看全文