CSS盒模型与正常流排版

一、盒模型

盒子模型从独立盒子结构以及多盒之间的关系两方面理解

盒子模型概念

独立盒子模型由:内容、border、padding、margin 四部分组成

  • 标准盒模型(w3c标准)的实际宽高 = width / height (内容宽高) + padding + border + margin
  • 怪异盒模型(IE标准)的 weight 和 height 包含了 padding 和 border
    怪异盒模型的实际宽高 = width / height (内容宽高 + padding + border) + margin

可以通过属性box-sizing来设置盒子模型的解析模式

  • content-box: 默认值,border和padding不算到width范围内,可以理解为是W3c的标准模型(default)
  • border-box:border和padding划归到width范围内,可以理解为是IE的怪异盒模型
  • padding-box:将padding算入width范围

盒子之间的关系

有标准流模式、“浮动”属性、“定位”属性

1. 标准文档流 / 标准流

指不使用一些特殊的排列和定位的 css 样式

  1. 块级元素
    在父元素中会自动换行,且跟同级的兄弟元素按照出现的顺序依次垂直排列,宽度自动铺满父元素宽度
    div、h1 -h6、 p 、pre 、hr、menu、noframes、noscript、dl、ul、ol 、fieldset、form、table

  2. 行内元素
    在父元素中水平排列,直到父元素的最右端才自动换行
    span, strong, em, br, img , input, label, select, textarea, cite, a,sub,sup
    行内元素设置的width和height无效,设置margin和padding只有左右边距有效

2. 盒子在标准流中的定位

用margin控制盒子与盒子之间的位置关系
(1)两个行内元素相邻时距离:左边的margin-right+右边的margin-left;
(2)不是行内元素,有换行效果的块级元素:上下间的距离是两者中的较大者,如上面的margin-bottom大于下面的margin-top,距离就取margin-bottom。
(3)当div嵌套时,子元素的margin将以父元素的内容区域为参考。
“标准流”中,块级元素没有设width和height时,默认宽度会自动延伸到父元素的内容区域为限,高度为包容下内容的最小高度。如果设置了width和height,就以值来显示。
(4)当margin为负数时。被设为负数的往相反方向移动,甚至会覆盖在其他元素上。当块级元素间形成嵌套的父子关系时,margin设为负数可以使子元素从父元素中分离出来

3. 盒子的浮动(float)

设置浮动后,盒子的宽高也会有改变。要清除浮动。也就是:(块级元素设置为浮动后,将脱离“标准流”,但还占据着父元素的空间,父元素的高度不再受浮动的子元素的影响,而由没浮动的其他子元素高度确定。)

4. 盒子的定位(position)
  • static(静态定位)
    表示元素在标准流中的默认位置。无任何效果。为默认值。
  • relative(相对定位)
    指定为relative后还要指定一定的偏移量,水平方向left、right,垂直方向top、bottom。
    偏移量是指与它原来所处的位置的移动距离。
    可以描述如下:
    1).相对定位,是以元素恩深在“标准流”中或者浮动的原本的位置为基准,通过偏移达到新位置。
    2).仍在标准流中,对父元素和兄弟元素无任何影响,即使由于偏移移到了父元素外边,其他元素也还在原来位置,不会顶上来。
  • absolute(绝对定位)
    也需要指定偏移量。
    1).绝对定位,从标准流中脱离,他们对其后的兄弟元素无任何影响。
    2).使用绝对定位的元素,以它“最近”的一个“已经定位”的“祖先元素”为基准进行偏移,如果没有已经定位的祖先元素,则以浏览器窗口为基准进行偏移。
    3).所谓已经定位:指position有设置,且不是设置为static的任意一种方式。
  • fixed(固定定位)
    以浏览器窗口为根据。

二、标准流 / 正常流

感性认识:简单且符合直觉,依次排列,排不下换行

拓展规则:
  • float 规则:
    使盒占用了正常流需要的空间,可以理解为“文字环绕”
  • vertital-align 规则:
    规定如何在垂直方向对齐盒
  • margin 规则:
    规定了元素自身周围所需要的空间
概念
  • 格式化上下文
    CSS 计算排版和布局的算法需要依赖一个排版的“当前状态”,这个当前状态称为“格式化上下文”

  • 块级盒(行级盒):使用块级格式化上下文
    行内级盒:使用行内级格式化上下文
排版基本规则

当我们要把正常流中的盒或文字排版,需要分为三种情况

  • 当遇到块级盒:排入块级格式化上下文
  • 当遇到行内级盒或文字:首先尝试排入行内级格式化上下文,如果排不下,那么创建一个行盒,先将行盒排版(行盒是块级,所以到第一种情况),行盒会创建一个行内级格式化上下文。
  • 遇到 float 盒:把盒的顶部跟当前行内级上下文上边缘对齐,然后根据 float 的方向把盒的对应边缘对到块级格式化上下文的边缘,之后重排当前行盒。

部分元素会在其内部创建新的块级格式化上下文:

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

推荐阅读更多精彩内容