代码改变世界

转:CSS布局奇淫技巧之-宽度自适应

  youxin  阅读(367)  评论(0编辑  收藏  举报

css这个东西,说难不难,说容易也不容易。我觉得最重要的还是经验的积累,正所谓的不积硅步,无以至千里。这一系列文章讲述几种css特殊布局的实现,也当作为自己做个备忘吧。

首先讲的是三列布局,左右两列宽度固定,中间一列宽度自适应

这个很好实现,左右两列分别左浮动和右浮动并给一个固定宽度,中间不浮动,也不设定宽度。(这个是有问题的,后面说明)这样基本就可以了。但为了兼容IE还必须做些工作。

看下代码结构:

效果为:

 

 

中间列要不要设置margin-left和margin-right ?

注意,中间那列需要把左右两个外边距分别设为左右两列的宽度,否则会有些问题。如下:

在谷歌、火狐等标准浏览器下是这样的(包括IE8+):

 

而在IE6、IE7中是这样的(图是在IE6下截的)

我们可以看到中间那列子元素的margin-left或margin-right的起点是不一致的,在IE6、IE7中,即使不给中间列设定margin-left和margin-right,它的子元素的左右外边距的起点仍然是在左右两列宽的的基础上的,就像是有margin-left和margin-right一样。所以为了各浏览器保持一致,中间那列还是设一个margin-left和margin-right为好。

IE6中的3px间隙bug

在上图的ie6截图中,我们看到各列之间有一条3px的间隔,这是只有IE6才有的问题。

如果中间那列的margin-left和margin-right都为0的话,则只要把左列的margin-right设为-3px,右列的margin-left设为-3px就行了。

但如果把中间列的margin-left和margin-right分别为左右两列的宽度时(上面已经说了,这也是必须这样做的),即使把左列的margin-right设为-3px,右列的margin-left设为-3px也还是没有效果。这时候还得把中间列的margin-left设为左列宽度-3px,margin-right设为右列宽度-3px才行。如下:

最终的代码

复制代码
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>宽度自适应布局</title>
<style>
body,div{ margin:0; padding:0;}
div{ height:200px; color:#F00;}
.left{ float:left; width:100px; background:#00f; _margin-right:-3px;}
.right{ float:right; width:100px; background:#0f0; _margin-left:-3px;}
.center{ background:#333; margin:0 100px; _margin:0 97px;}
</style>
</head>
<body>
<div class="left">我是left</div>
<div class="right">我是right</div>
<div class="center">我是center</div>
</body>
</html>
复制代码

个人说下上面的错误,看html代码:

<div class="left">我是left</div>
<div class="right">我是right</div>
<div class="center">我是center</div>

center在最后,我们把left,center分别float到两边,由于float是不占据位置的,center现在其实是占据了整行:
在下面的代码中我们故意把center的高度设置高点以便区分。center:
复制代码
<style>
body,div{
    margin:0;
    padding:0;
}
div{
    height:200px;
}
.left{
    float:left;
    width:100px;
    background:#00f;
}
.right{
    float:right;
    width;
    background:green;
}
.center{
    height:300px;
    background-color:#ccc;
}

</style>
</head>

<body>
<div class="left">我是left</div>
<div class="right">我是right</div>
<div class="center">我是center</div>
</body>
复制代码

显示如下:

以看到只是。center里面的文字在中间而已。center其实是占据整行 的,这个以前也讲过这个问题

所以,上面说不需设置margin是错误的。在.center增加:

margin-left:100px;
margin-right:100px;

显示为:

这下才将.center居中了

 

转自:http://www.cnblogs.com/2050/archive/2012/07/30/2614852.html

编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
历史上的今天:
2011-09-29 梦寐以求的编程语言
2011-09-29 你必须非常努力,才能看起来毫不费力
点击右上角即可分享
微信分享提示