页面布局(核心)

Misaka10032页面布局布局核心要素大约 15 分钟

网页布局过程:

  1. 先准备好相关的网页元素,网页元素基本都是盒子 Box。

  2. 利用 CSS 设置好盒子样式,然后摆放到相应位置。

  3. 往盒子里面装内容。

网页布局的核心本质:利用 CSS 摆盒子。

盒子模型

所谓盒子模型:就是把 HTML 页面中的布局元素看作是一个矩形盒子,盛装内容的容器。

CSS 盒子模型本质上是一个盒子,封装周围的 HTML 元素,包括:border 边框、margin 外边距、padding 内边距和 content 实际内容。

盒子模型
盒子模型

内边距 padding

设置内边距,即边框与内容之间的距离。

属性作用
padding-top上内边距
padding-right右内边距
padding-bottom下内边距
padding-left左内边距

复合写法

值的个数表达意思
padding: 5px;1 个值,代表上下左右都有 5px 内边距
padding: 5px 10px;2 个值,代表上下内边距 5px,左右内边距 10px
padding: 5px 10px 20px;3 个值,代表上内边距 5px,左右内边距 10px,下内边距 20px
padding: 5px 10px 20px 30px;4 个值,上是 5 像索 右 10 像素下 20 像素左是 30 像素顺时针

padding 同样影响盒子实际大小

  1. 内容和边框有了距离,添加了内边距。

  2. padding 影响了盒子实际大小。

  3. 盒子若已有宽高,此时再指定内边框,会撑大盒子。解决方案:如果保证盒子跟效果图大小保持一致,让宽高减去多出来的内边距大小。

  4. 内边距撑开盒子,当导航栏字数不一样多使用 padding 最合适。

  5. 如果盒子本身没有指定 width/height 属性,则此时 padding 不会撑开盒子大小

外边距 margin

设置外边距,即控制盒子和盒子之间的距离。

属性作用
margin-top上外边距
margin-right右外边距
margin-bottom下外边距
margin-left左外边距

复合写法与 padding 完全一致。

外边距可以让块级盒子水平居中,但是必须满足两个条件:

1.盒子必须指定了 width.

2.盒子左右的外边距都设置为 auto.

margin: 0 auto; 上下 0 外边距,左右居中。

注意:以上方法是让块级元素水平居中,行内元素或行内块元素给其父元素添加 text-align:center 即可。

外边距合并与塌陷(重要)

使用 margin 定义块元素的垂直外边距时,可能会出现外边距合并或塌陷。

  • 相邻块元素垂直外边距合并

上下相邻的两个兄弟块元素相遇,上面有 margin-bottom,下面又 margin-top,垂直间距取两个值中的较大者,该现象称为相邻块元素垂直外边距的合并。

解决方案:尽量只给一个盒子添加 margin 值。

  • 嵌套块元素垂直外边距塌陷

两个嵌套关系的父子块元素,父元素有上外边距同时子元素也有子外边距,此时父元素会塌陷较大的外边距值。

示例:红色 div 上下外边距均为 0,左右居中。红色 div 内嵌套的黄色 div 上部外边距 50px。由于嵌套块元素垂直外边距塌陷,导致整个 div 全下陷 50px。

外边距塌陷
<div
  style="width: 200px; height: 300px; margin: 0 auto; background-color: pink;"
>
  <div
    style="width: 200px; height: 300px; margin: 0 auto; background-color: red;"
  >
    <div
      style="width: 100px; height: 150px; margin: 50px auto; background-color: yellow;"
    ></div>
  </div>
</div>

解决方案

  • 为父元素定义上边框;

  • 为父元素定义上内边距;

  • 为父元素添加 overflow:hidden。

清除内外边距

网页元素很多都带有默认的内外边距,而且不同浏览器默认的也不一致。因此布局前首先要清除网页元素的内外边距。

* {
  padding: 0;
  margin: 0;
}

注意:行内元素为了照顾兼容性,尽量只设置左右内外边距,不要设置上下内外边距。但是转换为块级和行内块元素就可以了。

怪异盒模型 border-box

CSS 两种通过 box-sizing 来指定盒模型,content-box / border-box(CSS3 新属性),计算盒子大小的方式因此改变。

浏览器默认使用 content-box 盒模型。

  • box-sizing:content-box 盒子大小为 width/height + padding + border(默认)

  • box-sizing:border-box 盒子大小为 width/height

如果盒子模型我们改为 box-sizing: border-box,那么 padding 和 border 就不会撑大盒子,将不会再影响盒子实际大小(前提 padding 和 border 不会超过 width/height)

现开发已经普遍大量使用 border-box 盒模型。

浮动

CSS 提供了三种传统布局方式:普通流(标准流)、浮动、定位。

标准流

标签按照规定好默认方式排列。

  • 块级元素独占一行,从上向下顺序排列。

  • 行内元素按照顺序,从左到右顺序排列,碰到父元素边缘自动换行。

我们前面学习的就是标准流,标准流是最基本的布局方式。

注意:实际开发中,一个页面基本都包含了这三种布局方式(移动端会学习新的布局方式)。

浮动

很多布局效果,标准流没办法完成,可利用浮动完成。浮动可以改变元素标签默认的排列方式。

浮动最典型的应用:让多个块级元素一行内排列显示。


网页布局第一准则

多个块元素纵向排列找标准流,多个块级元素横向排列找浮动。


定义

float 用于创建浮动框,将其移动到一边,直到左边缘或右边缘触及包含块或另一个浮动框的边缘。

语法:选择器 { float : 属性值; }

属性值:none(默认值,元素不浮动); left 向左浮动; right 向右浮动。

浮动特性(重难点)

  1. 浮动元素脱离标准普通流的控制(浮)移动到指定位置(动)(脱标),浮动的盒子不再保留原先的位置

  2. 如果多个盒子都设置了浮动,则他们会按照属性值一行内显示并且顶端对齐排列。

浮动的元素是互相贴靠在一起的(不会有缝隙),如果父级宽度装不下这些浮动的盒子,多出的盒子会另起一行对齐。

  1. 浮动元素会具有行内块元素特性。

任何元素都可以浮动。不管原先是什么模式的元素,添加浮动之后具有行内块元素相似的特性。

如果行内元素有了浮动,不需要转换元素显示就可以直接给宽度和高度

块级盒子如果没有设置宽度,默认宽度和父级一样宽,添加浮动后,大小根据内容决定。行内元素同理

浮动元素应用场景

为了约束浮动元素位置,我们网页布局一般采取的策略是:

先用表主流的父元素排列上下位置,之后内部子元素采取浮动排列左右位置.符合网页布局第一准则。

浮动布局注意点

  1. 浮动和标准流的父盒子搭配

先用标准流的父元素排列上下位置,之后内部子元素采取浮动排列左右位置。

  1. 一个元素浮动,理论上其余的兄弟元素也要浮动

浮动的盒子只会影响浮动盒子后面的标准流,不会影响前面的标准流。理想中的状态,让子盒子撑开父盒子。


网页布局第二准则

先设置盒子大小,之后设置盒子的位置。


常见网页布局示例:

layout1
layout1
layout2
layout2
layout3
layout3

清除浮动

为什么需要清除浮动

父盒子不方便给高度,子盒子浮动不占有位置,父级盒子高度为 0,影响下面的标准流盒子。

由于浮动元素不再占有原文档流的位置,所以它会对后面的元素排版产生影响。

本质

清除浮动的本质是清除浮动元素造成的影响。

如果父盒子本身有高度,则不需要清除浮动。

清除浮动之后,父级就会根据浮动的子盒子自动检测高度。父级有了高度就不会影响下面的标准流。

语法

选择器 { clear: 属性值; }

left: 不允许左侧有浮动元素(清除左侧浮动)

right: 不允许右侧有浮动元素(清除右侧浮动)

both: 同时清除左右两侧浮动的影响

实际工作中,几乎只用 clear: both;

清除浮动的策略是:闭合浮动。只让浮动在父盒子内部影响,不影响父盒子外面的其他盒子

清除浮动四方法

  • 额外标签法(隔墙法),W3C 推荐做法。

额外标签法也称为隔墙法,是 W3C 推荐的做法。

额外标签法在浮动元素末尾添加一个空的标签。clear: both;

优点:通俗易懂,书写方便。

缺点:添加许多无意义的标签,结构化较差。

注意:要求这个新的空标签必须是块级元素。


  • 父级添加 overflow 属性。

可以给父级添加 overflow 属性,将其属性设置为 hidden、auto 或 scroll。

优点:代码简洁。

缺点:无法显示溢出的部分。


  • 父级添加 after 伪元素。

:after 方式是额外标签法升级版,也是给父元素添加。

.clearfix:after {
  content: "";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}
/* IE6、7专有 */
.clearfix {
  *zoom: 1;
}

优点:没有增加标签,结构更简单。

缺点:照顾低版本浏览器。

代表网站:百度、淘宝、网易等。


  • 父级添加双伪元素。

给父元素添加

.clearfix:before,
.clearfix:after {
  content: "";
  display: table;
}

.clearfix:after {
  clear: both;
}

.clearfix {
  *zoom: 1;
}

优缺点同上。

定位

为什么需要定位

  • 某个元素可以自由地在一个盒子内移动位置,并且压住其他盒子。

  • 滚动窗口的时候,盒子是固定在屏幕某个位置的。

以上效果,标准流或浮动都无法快速实现,需要定位来实现。

定位与浮动的区别

  1. 浮动可以让多个块级盒子一行没有缝隙排列显示,经常用于横向排列盒子。

  2. 定位则是可以让盒子自由地在某个盒子内移动位置或者固定屏幕中某个位置,并且可以压住其他盒子。

定位组成

将盒子定在某一个位置,所以定位也是在摆放盒子,按照定位的方式移动盒子。

定位=定位模式+边偏移。

定位模式 position

用于指定一个元素在文档中的定位方式。边偏移则决定了该元素的最终位置。

语义
static静态定位
relative相对定位
absolute绝对定位
fixed固定定位
sticky粘性定位

位置属性

盒子移动到的最终位置,有 top bottom left right 四个属性。

静态定位 statics

元素的默认定位方式,无定位的意思。

属性 position: static;

特点:

  1. 静态定位按照标准流特性摆放位置,它没有边偏移。

2.布局时很少使用。

相对定位 relative(重要)

元素在移动位置的时候,相对于它原来的位置来说的。

属性 position: relative;

特点:

  1. 相对于自己原来的位置来移动(移动位置的时候参照点是自己原来的位置)

  2. 原来在标准流的位置继续占有,后面的盒子仍然以标准流的方式对待它。(不脱标,继续保留原来位置)

绝对定位 absolute(重要)

绝对定位是元素在移动位置的时候,相对于它祖先元素而言的。

属性 position: absolute;

特点:

  1. 如果没有祖先元素或者祖先元素没有定位,则以浏览器为准定位(Document 文档)。

  2. 如果祖先元素有定位(相对、绝对、固定定位),则以最近一级的有定位祖先元素为参考点移动位置。

  3. 绝对定位不再占有原先的位置(脱标)。

固定定位 fixed(重要)

固定定位是元素固定于浏览器可视区的位置。主要使用场景:可以在浏览器页面滚动时元素的位置不会改变。

属性 position: fixed;

特点:

  1. 以浏览器的可视窗口为参照点移动元素。

  2. 跟父元素没有任何关系。

  3. 不随滚动条滚动。

  4. 固定定位不再占有原先的位置。

  5. 固定定位也是脱标的,其实固定定位也可以看做是一种特殊的绝对定位。

小技巧(固定在版心右侧位置)

1.让固定定位的盒子 left:50%,走到浏览器可视区一半位置。

2.让固定定位的盒子 margin-left:版心宽度一半距离,再移动版心宽度一半的位置。

粘性定位 sticky(了解)

sticky 跟前面四个属性值都不一样,它会产生动态效果,很像 relative 和 fixed 的结合:一些时候是 relative 定位(定位基点是自身默认位置),另一些时候自动变成 fixed 定位(定位基点是视口)。

属性 选择器 { position: sticky; top: 10px; }

sticky 能够形成"动态固定"的效果。比如,百度新闻首页的导航栏,初始加载时在自己的默认位置(relative 定位)

滚动条下滑变成固定定位,页面滚回去又会变成相对定位

特点:

  1. 以浏览器的可视窗口为参照点移动元素(固定定位特点)

  2. 粘性定位占有原先的位置(相对定位特点)

  3. 必须添加 top 、left、right、bottom 其中一个才有效

  4. 跟页面滚动搭配使用。兼容性较差,IE 不支持。

叠放次序 z-index

在使用定位布局时,可能会出现盒子重叠的情况。此时,可以使用 z-index 来控制盒子的前后次序(z 轴)

属性 z-index: 1;

特点:

  1. 数值可以是正整数、负整数或 0,默认 auto,数值越大,盒子越靠上。

  2. 如果属性值相同,则按照书写顺序,后来者居上。

  3. 数字后面不能加单位。

  4. 只有开启定位的盒子 z-index 属性才能生效。

子绝父相

子级或内部的元素是绝对定位的话,父级或外部元素要使用相对定位。

子级绝对定位,不会占有位置,可以放到父盒子里面任何一个地方,不会影响其他的兄弟盒子。

父盒子需要加定位限制子盒子在外部的父盒子内部显示。

父盒子布局时,需要占有位置,因此父亲只能是相对定位。

总结:因为父级需要占有位置,因此是相对定位,子盒子不需要占有位置,所以是绝对定位。

定位特殊性

  • 行内元素添加绝对或固定定位,可以直接设置高度和宽度。

  • 块级元素添加绝对或者固定定位,如果不给宽度或者高度,默认大小是内容的大小。

  • 脱标的盒子不会触发外边距塌陷(外边距合并)。浮动元素、绝对定位(固定定位)元素都不会触发外边距合并问题。

  • 绝对定位(固定定位)会完全压住盒子。

  • 浮动元素不同,只会压住它下面标准流的盒子,但是不会压住下面标准流盒子里面的文字(图片。)下图文字为<p>内文字。

效果演示:

浮动与绝对定位压盒子演示
<div class="d1">
  <div class="fl"></div>
  <p>阁下何不乘风起,扶摇直上九万里</p>
</div>
<div class="d1">
  <div class="pa"></div>
  <p>阁下何不乘风起,扶摇直上九万里</p>
</div>
.d1 {
  width: 300px;
  height: 50px;
  background-color: #e5e5e5;
}
.fl {
  float: left;
  width: 100px;
  height: 25px;
  background-color: #fff;
}
.pa {
  position: absolute;
  width: 100px;
  height: 25px;
  background-color: #fff;
}

定位总结

  • 相对定位、固定定位、绝对定位两大特点:

    1.是否占有位置(脱标);2.以谁为基准点移动位置。

  • 定位终点:子绝父相。

定位模式是否脱标移动位置是否常用
static 静态定位不能使用边偏移很少
relative 相对定位否(占有位置)相对于自身位置移动常用
absolute 绝对定位是(不占有位置)带有定位的父级常用
fixed 固定定位是(不占有位置)浏览器可视区常用
sticky 粘性定位否(占有位置)浏览器可视区当前阶段少

CSS 属性书写顺序(重要)

建议遵循顺序:

  1. 布局定位属性: display / position / float / clear / visibility / overflow(建议 display 第一个写,关系到显示模式)

  2. 自身属性:width / height / margin / padding / border / background

  3. 文本属性:color / font / text-decoration / text-align / vertical-align / white-space / break-word

  4. 其他属性(CSS3):content / cursor / border-radius / box-shadow / text-shadow / background: linear-gradient

页面布局整体思路

  1. 确定页面的版心(可视区域)。

  2. 分析页面中的行模块,以及每个行模块中的列模块。页面布局第一准则。

  3. 一行中的列模块经常浮动布局,先确定每个列的大小之后确定列的位置。页面布局第二准则。

  4. 制作 HTML 结构,遵循现有结构、后有样式的原则。结构永远最重要。

  5. 先理清楚布局结构,再写代码尤为重要。

网页布局总结

  1. 标准流

可以让盒子上下排列或左右排列,垂直的块级盒子显示用标准流布局。

  1. 浮动

可以让多个块级元素一行显示或者左右对齐盒子,多个块级盒子水平显示就用浮动布局。

  1. 定位

定位最大的特点是有层叠的概念,可以让多个盒子前后叠压来显示。如果元素自由在某个盒子内移动就用定位布局。