初识CSS布局

本文将简单学习几种基本的CSS布局方式:左右布局,左中右布局,水平居中,垂直居中。

左右布局

本文只介绍两种最基础的左右布局方式:浮动布局和绝对定位布局。

1. float + clearfix

在这里,我们使用的是给需要左右布局的元素添加浮动属性,同时为了消除浮动元素的bug,给浮动元素的爸爸添加 clearfix 类,class="clearfix"

HTML
  <div class="parent clearfix">
    <div class="left"> 
      left
    </div>
    <div class="right">
      right
    </div>
  </div>
CSS
.clearfix::after {
  content: '';
  display: block;
  clear: both;
}
.parent .left,
.parent .right {
  float: left;
}

2. absolute postion

同时我们还可以使用绝对定位来实现左右布局,给需要左右布局的元素添加 position:absolute,父元素添加 position: relativeposition:absolute 可以使子元素相对于祖先中的第一个 postion: relative 定位,然后我们可以通过 left 来调整布局元素的位置

HTML
  <div class="parent">
    <div class="left"> 
      left
    </div>
    <div class="right">
      right
    </div>
  </div>
CSS
.parent {
  position: relative;
}
.parent .left {
  position: absolute;
}
.parent .right {
  position: absolute;
  left:50%;
}

左中右布局

针对左中右布局,我们可以直接把左右布局的方式应用到这来,只需要布局的元素从两个拓展到多个。我们可以根据不同的需求使用浮动(float)或者绝对定位(absolute position)来实现左中右布局,实际情况中,我们需要结合需要选择适合的布局方式,在将来我们也会接触更多的布局方式 (flex布局,grid布局等)来应对不同的需求。
下面我们将使用浮动和绝对定位来实现一个简单的左中右布局。
左右栏元素各占100像素,中间自适应

1. 浮动布局

HTML
  <div class="parent clearfix">
    <div class="left"> 
      left
    </div>
    <div class="right">
      right
    </div>
    <div class="center">
      center
    </div>
  </div>

在这里 中间元素必须放在最后。

CSS
.clearfix::after {
  content: '';
  display: block;
  clear: both;
}
.parent .left {
  background: red;
  float: left;
  width: 100px;
}
.parent .right {
  background: blue;
  float: right;
  width:100px;
}
.parent .center {
  margin: 0 100px;
  background: gray;
}

2. 绝对定位布局

HTML
  <div class="parent">
    <div class="left"> 
      left
    </div>
    <div class="center">
      center
    </div>
    <div class="right">
      right
    </div>
  </div>
CSS
* {
  margin:0;
  padding: 0;
}
.parent {
  position: relative;
}

.parent .left {
  background: red;
  width:100px;
  position: absolute;
  top: 0;
  left: 0;
}

.parent .right {
  background: blue;
  width:100px;
  position: absolute;
  top: 0;
  right: 0;
}

.parent .center {
  background: gray;
  margin-left: 100px;
  margin-right: 100px;
}

区别

  1. 我们发现,当界面宽度小于200像素时,浮动布局右边的元素会被挤到下一行,然而绝对定位布局,左右元素仍然在在一行里面但是会重合在一起。
  2. 同时,我们注意到,浮动布局里中间的内容是需要在最后才能加载的,与此相对,绝对定位布局由于左右元素都脱离了文档流,所以左中右三个布局元素可以任意更改顺序。但是也正是由于左右元素脱离了文档流,这会导致一个问题,如果出现了左右元素的高度大于中间元素的时候,那么他们的父亲的高度就小于了左右元素的高度,这是需要注意的。

水平居中

1. text-align: center 和 display: inline-block

在这我们介绍一种最基础的水平居中的布局方式,使目标元素变为display: inline-block,然后再通过给它的父亲设置 text-align: center来设置水平居中。

HTML
  <div class="parent">
    <div class="child"> 
      content
    </div>
  </div>
CSS
.parent {
  text-align: center;
}
.child {
  display: inline-block;
  vertical-align: top;
}

注意这种方式会导致目标元素内的文字也被设置为居中,有时我们不需要元素内文字也居中时,需要在目标元素添加需要的text-align属性。
注意添加 display: inline-block 后,有一个bug,元素下面会多出一丝空隙,所以我们必须添加 vertical-align: top; 来取消这个空隙。

2. margin

同时我们还可以通过对块级元素设置 margin-left: automargin-right: auto 。但是相比较于第一种方式,这种方式我们建议要对块级元素要设置 max-width

3. padding

我们还可以通过由内而外给目标元素添加相同的左右 padding 来实现水平居中。

垂直居中

1. 父亲元素 padding

这里我们介绍一种十分简单的垂直居中方式,即通过给目标元素的父亲设置相等的上下padding,注意这个时候,我们推荐不要给父亲元素设置高度,要让他自动适应子元素的高度,除非我们能够计算出准确的父元素高度让其垂直居中。

HTML
  <div class="parent">
    <div class="child"> 
      content
    </div>
  </div>
CSS
.child {
  background: red;
}
.parent {
  padding: 100px 0;
  background: gray;
}

2. line-height,单行文本垂直居中

我们设置 line-heightheight一致时,则文本会自动垂直居中,然而我们一般避免设置height,容易导致潜在bug,也有可能出现实际不是设置的数值的情况。

HTML
  <div class="parent">
    <div class="child"> 
      content
    </div>
  </div>
CSS
.child {
  line-height: 40px;
  height: 40px;
  border: 1px solid red;
}

所以针对这种情况,我们往往推荐选择由内而外添加 padding, 来使其居中来避免添加height

CSS
.child {
  line-height: 22px;
  display: inline-block;
  padding: 10px 0;
  border: 1px solid red;
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,454评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,553评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,921评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,648评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,770评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,950评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,090评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,817评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,275评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,592评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,724评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,409评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,052评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,815评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,043评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,503评论 2 361
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,627评论 2 350

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,737评论 1 92
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,450评论 1 45
  • CSS 是什么 css(Cascading Style Sheets),层叠样式表,选择器{属性:值;属性:值}h...
    崔敏嫣阅读 1,475评论 0 5
  • 前面学习了使用HTML为网页添加内容,要对所添加的内容进行布局,就需要使用到CSS,JS等,这里就记录一下自己关于...
    wxyzcctn阅读 546评论 0 3
  • 每到周五梦琪就累的不行,一个多小时的足球然后接着去跳舞,今天踢球踢的时间有点晚梦琪饿的不能办,老师已经开始...
    高梦琪妈妈阅读 207评论 2 4