CSS三栏布局
一、绝对定位
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<style type="text/css">
.container{
position: relative;
}
.left{
position: absolute;
top: 0;
right: 0;
width: 100px;
height: 100px;
background: blue;
}
.right{
position: absolute;
top: 0;
right: 0;
width: 100px;
height: 100px;
background: green;
}
.center{
margin: 0px 100px;
height: 100px;
background: gray;
}
</style>
</head> <body>
<div class="container">
<div class="left">left</div>
<div class="center">center</div>
<div class="right">rigth</div>
</div>
</body>
</html>
二、浮动
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<style type="text/css">
.left{
float: left;
width: 100px;
height: 100px;
background-color: blue;
}
.right{
float: right;
width: 100px;
height: 100px;
background-color: red;
}
.center{
height: 100px;
margin: 0 100px;
background-color: green;
}
</style>
</head> <body>
<div>
<div class="left">left</div>
<div class="right">right</div>
<div class="center">center</div>
</div>
</body>
</html>
三、圣杯
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<style type="text/css">
.container{
height: 100px;
padding: 0 100px 0 100px;
}
.center{
float: left;
width: 100%;
height: 100%;
background: #808080;
}
.left{
position: relative;
left: -100px;
float: left;
width: 100px;
height: 100%;
background: red;
margin-left: -100%;
}
.right{
position: relative;
right: -100px;
float: left;
width: 100px;
height: 100%;
background: green;
margin-left: -100px;
}
</style>
</head> <body>
<div class="container">
<!-- 中间的 div 必须写在最前面 -->
<div class="center">center</div>
<div class="left">left</div>
<div class="right">rigth</div>
</div>
</body>
</html>
1.中间盒子的宽度设置为 width: 100%; 独占一行;
2.使用负边距(均是 margin-left)把左右两边的盒子都拉上去和中间盒子同一行;
.left {margin-left:-100%;} 把左边的盒子拉上去
.right {margin-left:-右边盒子宽度px;} 把右边的盒子拉上去
3.父盒子设置左右的 padding 来为左右盒子留位置;
4.对左右盒子使用相对布局来占据 padding 的空白,避免中间盒子的内容被左右盒子覆盖;
四、双飞翼
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<style type="text/css">
.container{
height: 100px;
}
.center{
float: left;
width: 100%;
height: 100%;
background: #808080;
}
.center-inner{
margin: 0 100px;
}
.left{
float: left;
width: 100px;
height: 100%;
background: red;
margin-left: -100%;
}
.right{
float: left;
width: 100px;
height: 100%;
background: green;
margin-left: -100px;
}
</style>
</head> <body>
<div class="container">
<!-- 中间的 div 必须写在最前面,并且中间的盒子再套一个div -->
<div class="center">
<div class="center-inner">center</div>
</div>
<div class="left">left</div>
<div class="right">rigth</div>
</div>
</body>
</html>
1.中间盒子的宽度设置为 width: 100%; 独占一行;
2.使用负边距(均是 margin-left)把左右两边的盒子都拉上去和中间盒子同一行;
3.在中间盒子里面再添加一个 div,然后对这个 div 设置 margin-left 和 margin-right来为左右盒子留位置;
五、圣杯和双飞翼异同
圣杯布局和双飞翼布局解决的问题是一样的,都是两边定宽,中间自适应的三栏布局,中间栏要在放在文档流前面以优先渲染。
两种方法基本思路都相同:首先让中间盒子 100% 宽度占满同一高度的空间,在左右两个盒子被挤出中间盒子所在区域时,使用 margin-left 的负值将左右两个盒子拉回与中间盒子同一高度的空间。接下来进行一些调整避免中间盒子的内容被左右盒子遮挡。
主要区别在于 如何使中间盒子的内容不被左右盒子遮挡:
圣杯布局的方法:设置父盒子的 padding 值为左右盒子留出空位,再利用相对布局对左右盒子调整位置占据 padding 出来的空位;
双飞翼布局的方法:在中间盒子里再增加一个子盒子,直接设置这个子盒子的 margin 值来让出空位,而不用再调整左右盒子。
简单说起来就是双飞翼布局比圣杯布局多创建了一个 div,但不用相对布局了,少设置几个属性。
六、Flexbox
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<style type="text/css">
.container{
display: flex;
flex-direction: row;
height: 100px;
}
.left{
flex-basis: 100px;
height: 100%;
background: #0000FF;
}
.center{
flex-grow: 1;
height: 100%;
background: gray; }
.right{
flex-basis: 100px;
height: 100%;
background: #0000FF;
}
</style>
</head> <body>
<div class="container">
<div class="left">left</div>
<div class="center">center</div>
<div class="right">rigth</div>
</div>
</body>
</html>
CSS三栏布局的更多相关文章
- Css三栏布局自适应实现几种方法
Css三栏布局自适应实现几种方法 自适应实现方法我们可以从三个方法来做,一个是绝对定位 ,自身浮动法 和margin负值法了,下面我们一起来看看这三个例子吧,希望例子能帮助到各位同学. 绝对定位法三栏 ...
- css三栏布局方案整理
日常开发中,经常会用到css三栏布局,现将工作中常用的css 三栏布局整理如下: 什么是三栏布局: 三栏布局,顾名思义就是两边固定,中间自适应. 一. float布局 <!DOCTYPE htm ...
- 三种方法实现CSS三栏布局
本文由云+社区发表 作者:前端林子 本文会分别介绍三种CSS实现三栏布局的方法,可在浏览器中打开查看效果 1.方法一:自身浮动的方法 实现方法:需要左栏向左浮动,右栏向右浮动,中间设左右margin来 ...
- CSS三栏布局的四种方法
总括: 不管是三栏布局还是两栏布局都是我们在平时项目里经常使用的,也许你不知道什么事三栏布局什么是两栏布局但实际已经在用,或许你知道三栏布局的一种或两种方法,但实际操作中也只会依赖那某一种方法,本文具 ...
- CSS 三栏布局入门
首先,我是CSS盲[只听说过box model],没动手实践过,关于margin padding只知名称,不明细节.刚看过一叶斋大哥关于css布局的博文,再动手实践,动手记录下点滴积累以备后用. &l ...
- CSS布局 - 三栏布局
CSS布局技术可谓是前端技术中最基础的技术,就是因为基础,所以我认为要更加熟练,深入的去掌握,去梳理. 一. 传统 ---> 浮动实现的三栏布局 采用浮动实现的三栏布局有以下特点及注意事项: · ...
- CSS布局:Float布局过程与老生常谈的三栏布局
原文见博客主站,欢迎大家去评论. 使用CSS布局网页,那是前端的基本功了,什么两栏布局,三栏布局,那也是前端面试的基本题了.一般来说,可以使用CSSposition属性进行布局,或者使用CSSfloa ...
- 转:CSS布局:Float布局过程与老生常谈的三栏布局
使用CSS布局网页,那是前端的基本功了,什么两栏布局,三栏布局,那也是前端面试的基本题了.一般来说,可以使用CSSposition属性进行布局,或者使用CSSfloat属性布局.前者适合布局首页,因为 ...
- 记一道css面试题 : 三栏布局两边宽度固定,中间宽度自适应,并且布局随屏幕大小改变。
前几天面试时有道css题没做出来,回来好好学习一番后把其记录下来. 题目是这样的:左中右三栏布局,左右两栏宽度固定,左右两栏的宽度为200像素,中间栏宽度自适应.当屏幕小于600px时,3栏会分别占用 ...
随机推荐
- 关于模板引擎handlebars.js基本用法
说明:模板引擎主要针对于渲染DOM,取代了字符串拼接,用下面的代码亲测handlebars模板引擎比字符串拼接渲染DOM慢了20ms, 这里配置一个在线DEMO,简单说明下handlebars.js的 ...
- Nodejs 和 Electron ubuntu下快速安装
查找时间管理软件的时候发现了superProductivity这个程序,使用electron进行开发,于是看了一下介绍,手痒了,尝试进行环境搭建,下一步慢慢补齐前端知识吧 nodejs安装 nodej ...
- userDefineFunc.js
var scareMe = function(){ console.log("cynthia") scareMe = function(){ console.log("w ...
- blfs(systemv版本)学习笔记-总页
我的邮箱地址:zytrenren@163.com欢迎大家交流学习纠错! lfs(systemv版本)学习笔记:https://www.cnblogs.com/renren-study-notes/p/ ...
- Python基础二字符串和变量
了解一下Python中的字符串和变量,和Java,c还是有点区别的,别的不多说,上今天学习的代码 Python中没有自增自减这一项,在转义字符那一块,\n,\r\n都是表示回车,但是对于不同的操作系统 ...
- C++知识回顾之__stdcall、__cdcel和__fastcall三者的区别
__stdcall.__cdecl和__fastcall是三种函数调用协议,函数调用协议会影响函数参数的入栈方式.栈内数据的清除方式.编译器函数名的修饰规则等. 调用协议常用场合 __stdcall: ...
- Linux 磁盘分区方案简析
Linux 磁盘分区方案简析 by:授客 QQ:1033553122 磁盘分区 任何硬盘在使用前都要进行分区.硬盘的分区有两种类型:主分区和扩展分区.一个硬盘上最多只能有4个主分区,其中一个主分区 ...
- Kotlin入门(10)七十二变的输入参数
上一篇文章介绍了Kotlin对函数的基本用法,包括函数的定义.输入参数的声明.输出参数的声明等等,这些足够对付简单的场合了.当然了,倘若一门新语言仅仅满足于这些雕虫小技,那也实在没什么前途.既然Kot ...
- Storm的DRPC
RPC:Remote Procedure Call DRPC:Distributed RPC Hadoop提供了RPC的实现机制,实现方法见:<>,本文主要介绍Storm的DRPC. ...
- Asp.Net Core 使用Quartz基于界面画接口管理做定时任务
今天抽出一点点时间来造一个小轮子,是关于定时任务这块的. 这篇文章主要从一下几点介绍: 创建数据库管理表 创建web项目 引入quarzt nuget 包 写具体配置操作,实现定时任务处理 第一步:创 ...