视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
CSS的经典三栏布局如何实现
2020-11-27 18:49:21 责编:小采
文档

这次给大家带来CSS的经典三栏布局如何实现,实现CSS的经典三栏布局的注意事项有哪些,下面就是实战案例,一起来看一下。

本文介绍了CSS经典三栏布局方案,分享给大家,也给自己做个笔记,具体如下:

三栏布局,顾名思义就是两边固定,中间自适应。三栏布局在开发十分常见

1. float布局

最简单的三栏布局就是利用float进行布局。首先来绘制左、右栏:

<style>
 .left {
 float: left;
 width: 100px;
 height: 200px;
 background-color: red;
 }
 
 .right {
 float: right;
 width: 100px;
 height: 200px;
 background-color: yellow;
 }
</style>
 
 <div class="container">
 <div class="left"></div>
 <div class="right"></div>
 <div class="main"></div>
 </div>

接下来再来看中间栏如何处理。我们知道对于float元素,其会脱离文档流,其他盒子也会无视这个元素。(但其他盒子内的文本依然会为这个元素让出位置,环绕在周围。)所以此时只需在container容器内添加一个正常的div,其会无视left和right,撑满整个container,只需再加上margin为left right流出空间即可:

<style>
 .left {
 float: left;
 width: 100px;
 height: 200px;
 background-color: red;
 }
 
 .right {
 float: right;
 width: 100px;
 height: 200px;
 background-color: yellow;
 }
 
 .main {
 background-color: green;
 height: 200px;
 margin-left: 120px;
 margin-right: 120px;
 }
 
 .container {
 border: 1px solid black;
 }
 
 <div class="container">
 <div class="left"></div>
 <div class="right"></div>
 <div class="main"></div>
 </div>

优势:简单

劣势:中间部分最后加载,内容较多时影响体验

2. BFC 规则

BFC(块格式化上下文)规则规定:BFC不会和浮动元素重叠。所以如果将main元素设定为BFC元素即可:

<style>
 .left {
 float: left;
 width: 100px;
 height: 200px;
 background-color: red;
 }
 
 .right {
 float: right;
 width: 100px;
 height: 200px;
 background-color: yellow;
 }
 
 .main {
 background-color: green;
 height: 200px;
 overflow: hidden;
 }
 
 <div class="container">
 <div class="left"></div>
 <div class="right"></div>
 <div class="main"></div>
 </div>

3. 圣杯布局

圣杯布局的核心是左、中、右三栏都通过float进行浮动,然后通过负值margin进行调整。

第一步,先来看下基本布局

<style>
 .left {
 float: left;
 width: 100px;
 height: 200px;
 background-color: red;
 }
 
 .right {
 float: left;
 width: 100px;
 height: 200px;
 background-color: yellow;
 }
 
 .main {
 float: left;
 width: 100%;
 height: 200px;
 background-color: blue;
 }
</style>
<body>
 <div class="container">
 <div class="main"></div>
 <div class="left"></div>
 <div class="right"></div>
 </div>
</body>

此时看到的效果是:左、右两栏被挤到第二行。这是因为main的宽度为100%。接下来我们通过调整左、右两栏的margin来将左、中、右放在一行中:

.left {
 float: left;
 width: 100px;
 height: 200px;
 margin-left: -100%;
 background-color: red;
}
 
.right {
 float: left;
 width: 100px;
 height: 200px;
 margin-left: -100px;
 background-color: yellow;
}

第二步,将left的margin-left设置为-100%,此时左栏会移动到第一行的首部。然后再将right的margin-left设置为其宽度的负值:-100px,则右栏也会移动到和左、中栏一行中:

不过此时还没有大功告成,我们试着在main中加入一些文字:

<body>
 <div class="container">
 <div class="main">fjlskdjflkasjdfljasdljlsjdljsdjflksadj</div>
 <div class="left"></div>
 <div class="right"></div>
 </div>
</body>

可以看到文字被压住了,接下来就要解决这个问题。

第三步,给container一个padding,该padding应该正好等于左、右栏的宽度:

.container {
 padding-left: 100px;
 padding-right: 100px;
}

此时看到的结果是左、中、右三栏都整体收缩了,但文字依然被压住了。

第四步,给左、右两栏加上相对布局,然后再通过设置left和right值向外移动:

.left {
 float: left;
 width: 100px;
 height: 200px;
 margin-left: -100%;
 position: relative;
 left: -100px;
 background-color: red;
}
 
.right {
 float: left;
 width: 100px;
 height: 200px;
 margin-left: -100px;
 position: relative;
 right: -100px;
 background-color: yellow;
}

到此为止,大功告成:

相信看了这些案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

相关阅读:

html5怎样做出图片转圈的动画效果

在h5里手机端页面缩放应该如何实现

怎样用H5 Canvas实现3D动态Chart图表

H5的FileReader分布读取文件应该如何使用以及其方法简介

下载本文
显示全文
专题