DIV+CSS 总结

写这篇博文主要是为了分享一下从传智播客里面学到的DIV+CSS技巧,同时也便于记不清的时候查看,完全是菜鸟一只,有不对的地方希望能够给我指正出来


继承性:

1.如果标签有自己的属性,那么就用自己的属性,不然会从上级继承,比如:

<style>
body{
      font-size:20px;
      color:red;
}
</style>

<body>

<ul>
<li>
没有自己的文字大小属性就继承
</li>
</ul>

<h1>有自己文字大小属性,就用自己的</h1>

</body>


2.margin ,padding,height,width等跟距离有关的属性不会被继承


3.文本相关属性是继承的:font-size,font-family,line-height,text-index等

4.列表相关属性是继承的:list-style-type等
5.颜色相关属性是继承的:color
6: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; 同时要用方向属性









你可能感兴趣的:(DIV+CSS 总结)