(一)标准模式和怪异模式的一些不同
(1)IE对盒模型的解析
在标准模式下,页面的宽度为:width+border+padding
在怪异模式下,width就包括了padding 和border
(2)在怪异模式下,如下的样式不能正常表现
width:200px;margin-left:auto;margin-right:auto;
在一些高级浏览器中,如果没有声明DTD类型,页面将会以标准模式进行解析,而在IE(IE6,IE7,IE8)中则会触发怪异模式
(二)关于*{margin:0;padding:0}
在不同浏览器中,一些默认样式也会有所不同,例如:ul默认带有缩进的样式,在IE中,其缩进是按照margin实现的,但是在firefox中,其缩进是按照padding实现的
为了去掉浏览器的默认样式,一些人会设置*{margin:0;padding:0},但是这并不是最好的写法,一般推荐如下写法:
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td{margin:0;padding:0}
(三)解决一些hack
(1)设置浮动时出现的bug:一旦为某个元素设置了浮动,然后有设置了margin属性,如下:
.fl{float;left; margin-left:20px};
这种在IE6中,margin值会加倍.解决办法:为设置的元素标签添加一个样式:display;inline;即可解决
(2)为了让浮动元素的父容器能够根据浮动元素的高度而自适应高度,有如下三种实现方法(其中fl类具有左浮动的样式,cb类具有clear:both的样式):
-- 让父元素同时浮动起来,例如:<div class="fl"><div class="fl"></div></div>
-- 让浮动元素后面紧跟一个用于浮动的空标签,例如:<div><div class="fl"></div><div class="cb"></div></div>
-- 给父容器挂上一个特殊的class,直接从父容器清除浮动元素的浮动,例如:<div class="clearfix"><div class="fl"></div></div>
其中.clearfix{height:1%;}
(3)IE的一些hack解决
--IE条件注释法:
<!-- [if IE 6]
<link type="text/css" href="ie6.css" rel="stylesheet"/>
-->
<!-- [if IE 7]
<link type="text/css" href="ie6.css" rel="stylesheet"/>
-->
<!-- [if IE 8]
<link type="text/css" href="ie6.css" rel="stylesheet"/>
-->
-- 选择符前缀法
.test{width:80px}
*html.test{width:60px} /只在IE6下有效
*+html .test{width:40px} /只在IE7下有效
-- 样式属性前缀法
.test{width:80px;*width:70px;_width:70px;}
(4)触发IE的hasLayout属性,
hasLayout是IE的一个特有的属性,用于css的解析引擎,要触发IE的hasLayout属性,需要使用如下的方法:
-- height:1%;这是早期的一种写法,现在并不适用.
-- zoom:1;
-- position:
(5)display:inline-block属性,这个样式在一下现代浏览器中都可以支持,但是在IE6和IE7中却不支持,但是即使不支持,这样设置会触发IE的hasLayout属性,使之显示块状效果
除此之外,display:inline-block只是对行内元素起作用,对块级元素不起作用,
(四)一些细节问题
(1)margin的不合理性:在混用了margin-top 和margin-bottom的情况下,两者的高度会产生重合,而相邻的两个元素定义margin-left和marfgin-right则不会发生重合.所以最好不要混用margin-top和margin-bottom
(2)权重原则
如下面的代码:
span{color:purple;font-size:10px;}
.test{color:red};
<span class="test">this is a test</span>这种情况应该听谁的呢
这个时候页面解析css样式的时候,都是会采取权重原则,谁的权重要大一些,则按照谁的样式来进行解析
权重的规则如下:
html的权重是1,class的权重为10,id的权重为100
eg:div em的权重为1+1=2,strong.demo的权重为1+10=11;如果两者的权重相同的情况,则哪个类后定义听谁的
eg:
<span class="test1 test2">this is a demo</span>
style定义如下:
.test1{color:red};
.test2{color:green};
这个时候应该听test2定义的样式
(3)解决超链接访问后hover不出现的问题
a:hover{color:yellow;}
a:visited{color:purple;}
<a href="#">this is demo</a>
结果超链接在点击之后,即使鼠标再悬浮在a上面,也不会出现变成yellow的情况,这就是存在的一个bug,解决办法:
a:visited{color:purple;}
a:hover{color:yellow;}
调换两者顺序即可,关于a标签的四钟状态的排序问题,有如下的顺序:link visited hover active
(4)对于relative,absolute和float,relative还有absolute会让元素浮起来,也就是改变z-index的值,但是relative只会让元素保留在z-index:0的区域,而页面上默认的
元素的z-index也是为0,这也就是relative不脱离文档流的原因,而absolute则会让元素的z-index大于0,从而使元素脱离文档流.对应的,float也能改变文档流,但是它仍然让
元素在z-index:0层保留
position:absolute和float会隐式地改变display类型,只要设置了position:absolute和float:left或者float:right中的任何一个,元素都会按照display:inline-block
的方式显示,即使显示地设置display:block或者display:inline,也没有用
(5)z-index属性的相关问题
z-index其实是z轴的一种体,z轴在元素设置position:absolute或者relative后被激活,其大小由z-index设置,但是在下面的例子中会反常:
<div id="one"></div>
<div id="two"></div>
<div id="three"></div>
<script type="text/javascript">
#one{width:300px;height: 300px;background: black;}
#two{width:100px;height: 100px;background: red;position: absolute;z-index: -1;left: 100px;top:250px;}
#three{width:100px;height: 100px;background: green;position: relative;z-index: 2;left: 120px;top:-100px;}
var one = document.getElementById('one');
var two = document.getElementById('two');
var three = document.getElementById('three');
one.onclick = function(){
alert('one');
}
two.onclick = function(){
alert('two');
}
three.onclick = function(){
alert('three');
}
</script>
在点击红色区域的时候不会弹出提示信息,原因是其z-index为0的body之下,被透明的body挡住了.
有些情况下虽然并没有显示设置z-index属性,但是也会显示z-index的属性,比如设定负边距,margin:-50px;仍然会让元素发生重叠的情况
(6)水平居中问题
--- 文本等行内元素水平居中:text-align:center;
--- 块级元素水平居中:margin:0 auto
--- 不确定宽度的块级元素水平居中
方法一:
<div class="wrap">
<table>
<tbody><tr><td>
<ul class="test">
<li><a href="">1</a></li>
</ul>
</td></tr></tbody>
</table>
<table>
<tbody><tr><td>
<ul class="test">
<li><a href="">1</a></li>
<li><a href="">2</a></li>
<li><a href="">3</a></li>
</ul>
</td></tr></tbody>
</table>
<table>
<tbody><tr><td>
<ul class="test">
<li><a href="">1</a></li>
<li><a href="">2</a></li>
<li><a href="">3</a></li>
<li><a href="">4</a></li>
</ul>
</td></tr></tbody>
</table>
</div>
由于table不是块级元素,如果不设定宽度的话,它的宽度由内部元素的宽度"撑起",将ul放在table,通过设定父级元素居中从而使ul居中,
方法二:
<style type="text/css">
ul{list-style: none;margin:0;padding: 0;}
.wrap{background: #000;width:500px;height: 100px;}
.test{text-align: center;padding:5px;}
.test li {display: inline;}
.test a{padding:2px 6px;background: #316AC5;color:#fff;border: 1px solid #316AC5;text-decoration: none}
.test a:hover{background: #fff;color:#316AC5;}
</style>
</head>
<body>
<div class="wrap">
<ul class="test">
<li><a href="">1</a></li>
<ul class="test">
<li><a href="">1</a></li>
<li><a href="">2</a></li>
<li><a href="">3</a></li>
</ul>
<ul class="test">
<li><a href="">1</a></li>
<li><a href="">2</a></li>
<li><a href="">3</a></li>
<li><a href="">4</a></li>
</ul>
</div>
通过将li这个块级元素改为行内元素让后设置text-align:center来进行居中
(7)垂直居中问题:
--- 父元素高度不确定的文本,图片,还有块级元素的竖直居中
<style type="text/css">
.wrap{background: #000;width:500px;color:#fff;margin-bottom: 10px;padding-top: 20px;padding-bottom: 20px;}
.test{width:200px;height: 50px;background: red;}
</style>
</head>
<body>
<div class="wrap">hello world</div>
<div class="wrap"><img src="book.jpg"/></div>
<div class="wrap"><div class="test"></div></div>
</body>
通过设定父容器的上下边距相同来实现的,
---父元素高度确定下的单行文本的垂直居中
height:20px;line-height:20px;
--- 父元素高度确定的多行文本,图片,块级元素的垂直居中
使用vertical-align:center;但是这个属性只有在父元素为td或者th的时候才会生效,所以可以使用table
<style type="text/css">
.wrap{background: #000;width:500px;color:#fff;height: 100px;}
.test{width:200px;height: 50px;background: red;}
</style>
</head>
<body>
<table><tbody><tr><td class="wrap">
hello world </br>
hello world</br>
hello world
</td></tr></tbody></table>
<table>
<tbody><tr><td class="wrap">
<img src="book.jpg"/>
</td></tr></tbody>
</table>
</body>