div+css布局漫谈 之 CSS布局常用的方法

1.CSS布局常用的方法:
float : none | left | right

取值:
none :  默认值。对象不飘浮
left :  文本流向对象的右边
right :  文本流向对象的左边

它是怎样工作的,看个一行两列的例子

xhtml:CSS:

< div  id ="warp" >
   
< div  id ="column1" > 这里是第一列 </ div >
   
< div  id ="column2" > 这里是第二列 </ div >
   
< div  class ="clear" ></ div >
</ div >

 

#wrap {  width : 100% ;  height : auto ; }
#column1
{  float : left ;  width : 40% ; }
#column2
{  float : right ;  width : 60% ; }
.clear
{  clear : both ; }  

position : static | absolute | fixed | relative

取值:

static :  默认值。无特殊定位,对象遵循HTML定位规则
absolute :  将对象从文档流中拖出,使用 left , right , top , bottom 等属性相对于其最接近的一个最有定位设置的父对象进行绝对定位。如果不存在这样的父对象,则依据 body 对象。而其层叠通过 z-index 属性定义
fixed :  未支持。对象定位遵从绝对(absolute)方式。但是要遵守一些规范
relative :  对象不可层叠,但将依据 left , right , top , bottom 等属性在正常文档流中偏移位置

它来实现一行两列的例子

xhtml:

<div id="warp">
 <div id="column1">这里是第一列</div>
 <div id="column2">这里是第二列</div>
</div>

CSS:

#wrap{ position:relative;/*相对定位*/width:770px;}
#column1{ position:absolute; top:0; left:0; width:300px;}
#column2{position:absolute; top:0; right:0; width:470px;}

他们的区别在哪?

显然,float是相对定位的,会随着浏览器的大小和分辨率的变化而改变,而position就不行了,所以一般情况下还是float布局!

2.CSS常用布局实例

一列
单行一列

body  { margin: 0px;   padding: 0px;  text-align: center;  }
#content 
{  margin-left:auto;  margin-right:auto;  width: 400px;}

 

两行一列三行一列

body  {   margin :  0px ;    padding :  0px ;    text-align :  center ; }
#content-top 
{  margin-left : auto ;    margin-right : auto ;  width :  400px ;   }
#content-end 
{ margin-left : auto ;  margin-right : auto ;   width :  400px ;   }

 

body  {   margin :  0px ;  padding :  0px ;   text-align :  center ;    }
#content-top 
{   margin-left : auto ;   margin-right : auto ;   width :  400px ; }
#content-mid 
{  margin-left : auto ;  margin-right : auto ;   width :  400px ; }
#content-end 
{  margin-left : auto ;  margin-right : auto ;  width :  400px ;    }

两列
单行两列
两行两列

#bodycenter  {  width :  700px ; margin-right :  auto ;  margin-left :  auto ; overflow :  auto ;    }
#bodycenter #dv1 
{ float :  left ; width :  280px ; }
#bodycenter #dv2 
{ float :  right ; width :  410px ; }

 

#header {     width :  700px ;  margin-right :  auto ; margin-left :  auto ;  overflow :  auto ; }
#bodycenter 
{  width :  700px ;  margin-right :  auto ;  margin-left :  auto ;  overflow :  auto ;   }
#bodycenter #dv1 
{  float :  left ;  width :  280px ; }
#bodycenter #dv2 
{  float :  right ; width :  410px ; }

 

#header {     width :  700px ; margin-right :  auto ;  margin-left :  auto ;    }
#bodycenter 
{ width :  700px ;  margin-right :  auto ;  margin-left :  auto ;    }
#bodycenter #dv1 
{   float :  left ; width :  280px ; }
#bodycenter #dv2 
{  float :  right ;   width :  410px ; }
#footer
{      width :  700px ;   margin-right :  auto ;  margin-left :  auto ;   overflow :  auto ;    }

三列
单行三列
绝对定位

#left  {  position :  absolute ;  top :  0px ;   left :  0px ;  width :  120px ;    }
#middle 
{ margin :  20px 190px 20px 190px ;   }
#right 
{ position :  absolute ; top :  0px ;  right :  0px ;   width :  120px ; }

 

< div  id ="warp" >
 
< div  id ="column" >
 
< div  id ="column1" > 这里是第一列 </ div >
 
< div  id ="column2" > 这里是第二列 </ div >
 
< div  class ="clear" ></ div >
 
</ div >
 
< div  id ="column3" > 这里是第三列 </ div >
 
< div  class ="clear" ></ div >
</ div >

 

#wrap {  width : 100% ;  height : auto ; }
#column
{  float : left ;  width : 60% ; }
#column1
{  float : left ;  width : 30% ; }
#column2
{  float : right ;  width : 30% ; }
#column3
{  float : right ;  width : 40% ; }
.clear
{  clear : both ; }  

float定位二

xhtml:

  < div  id ="center"  class ="column" >
  
< h1 > This is the main content. </ h1 >
 
</ div >
 
< div  id ="left"  class ="column" >
  
< h2 > This is the left sidebar. </ h2 >
 
</ div >
 
< div  id ="right"  class ="column" >
  
< h2 > This is the right sidebar. </ h2 >
 
</ div >

 

body  { margin :  0 ; padding-left :  200px ; padding-right :  190px ; min-width :  240px ; }
.column 
{ position :  relative ; float :  left ; }
#center 
{ width :  100% ; }
#left 
{ width :  180px ;  right :  240px ; margin-left :  -100% ; }
#right 
{ width :  130px ; margin-right :  -100% ; }

 

xhtml:

< div  id ="header" > 这里是顶行 </ div >
< div  id ="warp" >
 
< div  id ="column" >
 
< div  id ="column1" > 这里是第一列 </ div >
 
< div  id ="column2" > 这里是第二列 </ div >
 
< div  class ="clear" ></ div >
 
</ div >
 
< div  id ="column3" > 这里是第三列 </ div >
 
< div  class ="clear" ></ div >
</ div >

 

#header { width : 100% ;  height : auto ; }
#wrap
{  width : 100% ;  height : auto ; }
#column
{  float : left ;  width : 60% ; }
#column1
{  float : left ;  width : 30% ; }
#column2
{  float : right ;  width : 30% ; }
#column3
{  float : right ;  width : 40% ; }
.clear
{  clear : both ; }  

 

xhtml:

< div  id ="header" > 这里是顶行 </ div >
< div  id ="warp" >
    
< div  id ="column" >
    
< div  id ="column1" > 这里是第一列 </ div >
    
< div  id ="column2" > 这里是第二列 </ div >
     
< div  class ="clear" ></ div >
 
</ div >
 
< div  id ="column3" > 这里是第三列 </ div >
      
< div  class ="clear" ></ div >
</ div >
< div  id ="footer" > 这里是底部一行 </ div >

 

#header { width : 100% ;  height : auto ; }
#wrap
{  width : 100% ;  height : auto ; }
#column
{  float : left ;  width : 60% ; }
#column1
{  float : left ;  width : 30% ; }
#column2
{  float : right ;  width : 30% ; }
#column3
{  float : right ;  width : 40% ; }
.clear
{  clear : both ; }  
#footer
{ width : 100% ;  height : auto ; }

 

3.CSS布局高级技巧

margin和padding总是有可能要用到,而产生的问题如何解决呢?由于浏览器解释容器宽度的方法不同:

IE 6.0 Firefox Opera等是
真实宽度=width+padding+border+margin
IE5.X
真实宽度=width-padding-border-margin

很明显,第一种下很完美的布局在第二种情况下后果是很凄惨的!

解决的方法是 hack

具体解释点击下面链接查看

www.blueidea.com/tech/site/2006/3170.asp
www.jluvip.com/blog/article.asp?id=114

列等高技巧

n行n列布局,每列高度(事先并不能确定哪列的高度)的相同,是每个设计师追求的目标,做法有:背景图填充、加JS脚本的
方法和容器溢出部分隐藏和列的负底边界和正的内补丁相结合的方法。

背景图填充法:

xhtml:

< div  id ="wrap" >
< div  id ="column1" > 这是第一列 </ div >
< div  id ="column1" > 这是第二列 </ div >
< div  class ="clear" ></ div >
</ div >

 

#wrap {  width : 776px ;  background : url(bg.gif) repeat-y 300px ; }
#column1
{  float : left ;  width : 300px ; }
#column2
{  float : right ;  width : 476px ; }
.clear
{  clear : both ; }

 

JS脚本法:

www.blueidea.com/bbs/NewsDetail.asp?id=2453983
代码的原理基本就是这样,读取高度,判断高度,高度相等。

容器溢出部分隐藏和列的负底边界和正的内补丁相结合的方法

这篇文章说的很详细了:

www.blueidea.com/tech/web/2006/3210.asp

还有:

www.jluvip.com/blog/article.asp?id=151

满屏高度布局(最窄770px最宽1024px经典布局)

www.blueidea.com/tech/web/2005/3124.asp

 

就是将一个npx宽的一张图片在外部容器纵向重复,定位到两列交错的位置纵向重复,在视觉上产生了两列高度一样的错觉
css:

 

div.content {
width:400px; //这个是错误的width,所有浏览器都读到了
voice-family: "/"}/""; //IE5.X/win忽略了"/"}/""后的内容
voice-family:inherit;
width:300px; //包括IE6/win在内的部分浏览器读到这句,新的数值(300px)覆盖掉了旧的
}
html>body .content { //html>body是CSS2的写法
width:300px; //支持CSS2该写法的浏览器(非IE5)有幸读到了这一句
}

div.content {
width:300px !important; //这个是正确的width,大部分支持!important标记的浏览器使用这里的数值
width(空格)/**/:400px; //IE6/win不解析这句,所以IE6/win仍然认为width的值是300px;而IE5.X/win读到这句,新的数值(400px)覆盖掉了旧的,因为!important标记对他们不起作用
}
html>body .content { //html>body是CSS2的写法
width:300px; //支持CSS2该写法的浏览器有幸读到了这一句
}

PS:这里列出的是常用的例子,而非研究之用,对一每个盒子,我都没有设置margin,padding,boeder等属性,是因为我个人觉得,含有宽度定位的时候,最好不好用到他们,除非必不得已,因为如果不是这样的话,解决浏览器兼容问题,会让你头疼,而且产生一系列CSS代码,我觉得这样的效率和效果都不好!
CSS:
CSS:三行三列
CSS:两行三列
float定位
xhtml:CSS: 
三行两列
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值