最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

CSS的经典三栏布局如何实现

来源:懂视网 责编:小采 时间:2020-11-27 18:49:21
文档

CSS的经典三栏布局如何实现

CSS的经典三栏布局如何实现:这次给大家带来CSS的经典三栏布局如何实现,实现CSS的经典三栏布局的注意事项有哪些,下面就是实战案例,一起来看一下。本文介绍了CSS经典三栏布局方案,分享给大家,也给自己做个笔记,具体如下:三栏布局,顾名思义就是两边固定,中间自适应。三栏布局在开
推荐度:
导读CSS的经典三栏布局如何实现:这次给大家带来CSS的经典三栏布局如何实现,实现CSS的经典三栏布局的注意事项有哪些,下面就是实战案例,一起来看一下。本文介绍了CSS经典三栏布局方案,分享给大家,也给自己做个笔记,具体如下:三栏布局,顾名思义就是两边固定,中间自适应。三栏布局在开

这次给大家带来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分布读取文件应该如何使用以及其方法简介

文档

CSS的经典三栏布局如何实现

CSS的经典三栏布局如何实现:这次给大家带来CSS的经典三栏布局如何实现,实现CSS的经典三栏布局的注意事项有哪些,下面就是实战案例,一起来看一下。本文介绍了CSS经典三栏布局方案,分享给大家,也给自己做个笔记,具体如下:三栏布局,顾名思义就是两边固定,中间自适应。三栏布局在开
推荐度:
标签: 如何 实现 经典
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top