写这篇博文主要是为了分享一下从传智播客里面学到的DIV+CSS技巧,同时也便于记不清的时候查看,完全是菜鸟一只,有不对的地方希望能够给我指正出来
继承性:
1.如果标签有自己的属性,那么就用自己的属性,不然会从上级继承,比如:
<style> body{ font-size:20px; color:red; } </style> <body> <ul> <li> 没有自己的文字大小属性就继承 </li> </ul> <h1>有自己文字大小属性,就用自己的</h1> </body>
3.文本相关属性是继承的:font-size,font-family,line-height,text-index等
4.列表相关属性是继承的:list-style-type等
5.颜色相关属性是继承的:color6:button, input, select, textarea在IE下是不继承body属性的,需单独书写
技巧:
写CSS的时候第一步就是将所有能用到的标签的内外边距归零如:body,ul,li,div,table,h1,p{margin:0;padding:0;}
ul,li,ol这两个标签很容易出现兼容性问题,所以都用这种方式ul,li,ol{margin:0px;padding:0px;list-style:none; }
border-color:这个属性必须用在border:1px;这种先定义粗细的属性之后,否者不管用
想要使内容或别的元素真正的居中的时候将左右的margin:不用固定的值二十auto;
做分割线的时候可以不用hr,而是用div的border属性可以控制各条边的宽度
让div中的内容水平居中时用text-algin,而垂直居中用的方法是设置行高line-height等于div的高度,如div的heigth=100px;那么设置line-height:100px;
background-image背景图片的依附方式:fixed(固定)的含义是固定在屏幕上(可视区域),而不是标签上面
background-attachment:fixed在ie6上面存在兼容性问题,如果要实现效果,只有一个办法可以解决,那就是写在支持它的两个标签中,第一个是html,第二个是body标签,基本上别无他法了
可以用css精灵减少http对服务器的请求而加快访问速度
<input type="checkbox"> 默认是带有margin和border属性的,即使对input的整体清零也没用,需要单独给它写一个margin:0px; border:0px;比较好
在IE6中,当父元素里面的子元素的高度超过了父元素设定的高度的时候,那么父元素的高度将会被子元素撑地和子元素的高度一样
float(浮动)相当于块元素(如div)飘起来了,也就是说脱离了文档流,那么它下面的内容就会向上移动。有时下面的块移动上来的时候发现上面被占据了,那么刚移动上来的元素就紧接在右边
如果想让多个块元素(比如DIV)显示在同一行中,那么就把浮动设置成同一个方向,而不是左边的元素设置成左飘动,右边元素设置成右飘动,这样做可以更好的兼容不同的浏览器
每写一个div的时候都要给它加上一个宽度值,不然就会使100%宽度
当对一个块设置成浮动(float)属性后,就要重新检查跟这个块有关的margin,padding,text-algin等跟距离有关的属性是否还起作用,特别是那些设置成auto的值基本上都不管用了
一行有多个浮动块的时候必须把这些浮动块全部放到一个大的块(div)中,而且这个大的块还必须加上宽度才能有更强的兼容性
当父元素没有自己的高度的时候,并且父元素的子元素(怎么说呢?就是里面的那个元素)带有浮动属性,那么父元素的高度酒不会自己增加(父元素的高度不会随着子元素自适应) 在不同的ie效果也不同,测试效果如下:
<!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>无标题文档</title> <style type="text/css"> body,div{ margin:0px; padding:0px; } #header{ height:100px; width:960px; background:#036; margin:0px auto; } #main{ width:960px; height:500px;/*当注释掉高度之后就有大问题了:当父元素没有自己的高度的时候,并且父元素的子元素(怎么说呢?)带有浮动属性,那么父元素的高度酒不会自己增加(父元素的高度不会随着子元素自适应)*************这个地方的效果就是应为父元素没有高度,导致背景色显示不出来,可以加上border证明*/ background:#906; margin:0px auto; } #left{ width:360px; height:500px; background:red; float:left; } #right{ width:400px; height:500px; background:green; float:left; } #footer{ height:50px; width:960px; background:yellow; clear:both; margin:0px auto 0px;; } </style> </head> <body> <div id="header">头 </div> <div id="main"> <div id="left">左 </div> <div id="right">右 </div> </div> <div id="footer">版权 </div> </body> </html>
当出现上面的问题时,解决的方法有如下几种:
方法一:
w3c的建议:在父元素的里面,也就是父元素里面最后的一个块(div)里面再加上一个空的div,这个div带有清除浮动的属性,唯一一个不好的地方就是加了一个什么功能都没的div而增加了代码量;
代码改成如下:
<!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>无标题文档</title> <style type="text/css"> body,div{ margin:0px; padding:0px; } #header{ height:100px; width:960px; background:#036; margin:0px auto; } #main{ width:960px; /*height:500px;当注释掉高度之后就有大问题了:当父元素没有自己的高度的时候,并且父元素的子元素(怎么说呢?)带有浮动属性,那么父元素的高度酒不会自己增加(父元素的高度不会随着子元素自适应)*************这个地方的效果就是应为父元素没有高度,导致背景色显示不出来,可以加上border证明*/ background:#906; margin:0px auto; } #left{ width:360px; height:500px; background:red; float:left; } #right{ width:400px; height:500px; background:green; float:left; } #footer{ height:50px; width:960px; background:yellow; clear:both; margin:0px auto 0px;; } </style> </head> <body> <div id="header">头 </div> <div id="main"> <div id="left">左 </div> <div id="right">右 </div> <div style="clear:both;"></div> <!--新加的一个带有清除浮动属性的空div--> </div> <div id="footer">版权 </div> </body> </html>
方法二:给父元素加上:overflow:hidden;代码入校:
<!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>无标题文档</title> <style type="text/css"> body,div{ margin:0px; padding:0px; } #header{ height:100px; width:960px; background:#036; margin:0px auto; } #main{ width:960px; /*height:500px;当注释掉高度之后就有大问题了:当父元素没有自己的高度的时候,并且父元素的子元素(怎么说呢?)带有浮动属性,那么父元素的高度酒不会自己增加(父元素的高度不会随着子元素自适应)*************这个地方的效果就是应为父元素没有高度,导致背景色显示不出来,可以加上border证明*/ background:#906; margin:0px auto; overflow:hidden; } #left{ width:360px; height:500px; background:red; float:left; } #right{ width:400px; height:500px; background:green; float:left; } #footer{ height:50px; width:960px; background:yellow; clear:both; margin:0px auto 0px;; } </style> </head> <body> <div id="header">头 </div> <div id="main"> <div id="left">左 </div> <div id="right">右 </div> </div> <div id="footer">版权 </div> </body> </html>
方法二是最推荐的一个方法,但是如果子元素出现了定位布局,那么方法二作废,此时就用方法一
当需要使用绝对定位时需要满足两个条件,缺一不可,否者浏览器兼容问题:
(1)。父元素必须要有自己的定位属性,建议使用position:relative;
(2).。子元素要有自己的绝对定位属性,position:absolute; 同时要用方向属性;