阅读MDN文档之基本盒模型(三)
- Box properties
- Active learning: playing with boxes
- Advanced box manipulation (先进的盒子操作)
- Types of CSS boxes
Box properties
content
padding
border
margin
Note: Margins have a specific behavior called margin collapsing: When two boxes touch against one other, the distance between is the value of the value of the largest of the two touching margins, and not their sum.
Margin collapsing
Margin collapsing occurs in three basic cases.
Adjacent siblings(相邻兄弟)
The margins of adjacent(相邻的) siblings(兄弟) are collapsed(except when the later sibling needs to be cleared past floats).For example:
<p>The bottom margin of this paragraph is collapsed...</p>
<p>...with the top margin of this paragraph.</p>
Parent and first/last child
If there is no border, padding, inline content, block_formatting_context(BFC) created or dearance(清除) to seperate the margin-top of a block from the margin-top of its first child block, or no border, padding, inline content, height, min-height, or max-height to seperate the margin-bottom of a block from the margin-bottom of its last child, then those margins collapse. The collapsed margin ends up outside the parent.
如果这里没有border, padding, 内联内容, BFC的创建或清除, 来将块的margin-top与其第一个子块的margin-top分开。或者没有border, padding, inline content, height, min-height, or max-height, 来将块的margin-bottom和最后一个子块的margin-bottom分开,那么这些margins会塌陷。塌陷的margin结束于父容器的外面。
Empty blocks
If there is no border, padding, inline content, height or min-height to sperate a block's margin-top from its margin-bottom, then its top and bottom margins collapse.
Active learning: playing with boxes
如果设置padding或者margin的宽度是百分比的话, 是相对于父容器的宽度(只是cotent,不包括padding和margin)。
Borders ignore percentages width settings too, but you can use padding to simulate(模仿,假装).
You should have noticed that the total width of a box is the sum of its width, padding-left, padding-right, boder-left, border-right properties. In some cases it annoying (for example, what if you want to have a box with a total width of 50% with border and padding expressed in pixels?) To avoid such problems, it's possible to tweak(用力拉) the box model with property box-sizing. With the value border-box, it changes the box model to this new one (width = content + border + padding; height = content + border + padding).
Advanced box manipulation (先进的盒子操作)
Overflow
When you set the size of a box with absolute value(e.g. a fixed pixel width/height), the content may not fit within the allowed size, in which case the content overflows the box. To control what happens in such cases, we can use the overflow property. It takes several possible values, but the most common are:
auto: If there is too much content, the overflowing content is hidden and scroll bars are shown to let the user scroll to see all the content.
hidden: If there is too much content, the overflowing content is hidden.
visible: If there is too much content, the overflowing content is shown outside of the box(this is usually the default behavior.)
Background clip
Box backgrounds are made up of colors and images, stacked on top of each other(background-color, background-image.) They are applied to a box and drawn under that box.By default, backgrounds extend to the outer of the border.This is often fine, but in some cases it can be annoying (what if you have a tiled(平铺的) background image that you want to only extend to the edge of the content?) This behavior can be adjusted by setting background-clip property on the box.
border-box(this is default)
padding-box
content-box
Outline
使用起来和border差不多,但是它不是盒模型的一部分。
Types of CSS boxes
Everything we're said so far applies to boxes that represented block level elements(块级元素). However, CSS has other types of boxes that behave differently. The type of box applied to an element is specified by the display property. There are many different values available for display, but in this article we will focus on the three most common ones ones;block, inline and inline-block.
- A block box is defined as a box that's stacked upon other boxes(i.e. content before and after the box appears on a seperate line), and can have width and height set on it. The whole box model as described above applies to block boxes.(块级元素是这样的一个盒子,它堆放在其他盒子上面(补充说明:内容前后都有一个空行,也就是说,block独占一行), 可以设置宽度和高度。上面说的整个盒模型都适用于块级元素。)
- An inline box is the opposite of a block box: it flows with the document's text(i.e. it will appear on the same line as surrounding text and other inline elements, and its content will break with the flow of the text, like lines of text in a paragraph.) Width and height settings have no effect on inline boxes;any padding, margin, border set on inline boxes will update the position of surrounding text, but will not affect the position of surrounding block boxes.(内联框与块框相反:它与文档的文本一起流动(即,它将与周围文本和其他内联元素显示在同一行上,其内容将与文本流断开,如文本行 在一个段落中。)宽度和高度设置对内联框没有影响; 在内嵌框中设置的任何填充,边距和边框将更新周围文本的位置,但不会影响周围块框的位置。
) - An inline-block box is something in between the first two: it flows with surrounding text without creating line breaks before and after it like an inline box, but it can be sized using width and height and maintains its block integrity(完整) like a block box --- it won't be broken across paragraph lines.
更多的BFC、Visual formatting model
阅读MDN文档之基本盒模型(三)的更多相关文章
- 阅读MDN文档之CSS选择器介绍(一)
本文为阅读MDN文档笔记 目录 Different types of Selectors Attribute Selectors Presence and value attribute select ...
- 阅读MDN文档之StylingBoxes(五)
目录 BoxModelRecap Box properties Overflow Background clip Background origin Outline Advanced box prop ...
- HTML文档模式与盒模型
HTML文档根据文档顶部的doctype声明来决定渲染模式,有标准模式(Standards Mode)与怪异模式(Quirks mode,或叫做混杂模式)两种模式. IE5及以前默认总是表现为怪异模式 ...
- 阅读MDN文档之布局(四)
Introducing positioning Static positioning Relative positioning Introducing top, bottom, left and ri ...
- 阅读MDN文档之布局(四)
Introducing positioning Static positioning Relative positioning Introducing top, bottom, left and ri ...
- 阅读MDN文档之层叠与继承(二)
目录 The cascade Importance Specificity Source order A note on rule mixing Inheritance Controlling inh ...
- Emacs阅读chm文档
.title { text-align: center; margin-bottom: .2em } .subtitle { text-align: center; font-size: medium ...
- 前端开发必备之MDN文档
想下载MDN文档的看前面的内容就可以了. HTML 源码下载 MDN官方下载地址:https://developer.mozilla.org/media/developer.mozilla.org.t ...
- MDN 文档高级操作进阶教程
MDN 文档高级操作进阶教程 MDN 文档, 如何优雅的使用 MDN 文档上的富文本编辑器 pre & 语法高亮器 code & note box source code 上传附件 i ...
随机推荐
- selenium+python对页面元素进行高亮显示
调用js方法: execute_script(script,*args) Arguments对象: 类数组对象,代表传给一个function的参数列表,当前函数的内置属性,其长度是由实参个数决定而不是 ...
- ThinkPHP中对系统常量的使用
/Wen 当前模块的URL地址 /Wen/postname 当前操作的URL地址 /thinkphp-changliang/ 当前URL地址 APP_DEBUG 是否开启调试模式(框架两种模式:[默认 ...
- 基于git的代码版本管理规范及流程-简版
基于git的简单实用的版本管理规范及流程,包括:代码库的分布.人员角色的划分.代码提交合并流程.代码冲突处理.分支管理. 代码库分类 根据代码库分布的位置及作用,分为以下几类: 主库:位于服务端,所有 ...
- Mac下CUDA开启及Tensorflow-gpu安装
本文由@ray 出品,转载请注明出处. 文章链接:http://www.cnblogs.com/wolfray/p/8040694.html 在之前的文章中,笔者介绍了在Mac下安装Tensorfl ...
- Java SE 8 流库(二)
1.3. filter,map,flatMAP方法 流的转换会产生一个新流,它的元素派生出自另一个流中的元素: Stream<T> filter(Predicate<? super ...
- 【本地资源路径&&网络资源路径&&正反斜杠在Java中的用法】
一.概念和用法 左正右反 先来看看转义字符的概念:通过 \ ,?来转变后面字母或符号的含义.意思就是改变字母本身的含义. 以"\"符号为例,JAVA中有很多操作,例如文件操作等,需 ...
- object-fit?
知道有这个属性存在,是一个很偶然的机会.有一天,设计部的一个小伙伴给了我一个网址,说很有个性,让我看一下,当发现一个很有意思的效果时,作为一个前端小兵的我当然是第一时间开始审查元素,然后看到了这个从没 ...
- 中小企业为什么要上HR系统
人力资源不不过公司资源.也是一种社会资源. 越来越多的企业已将人作为一种重要的资源来看待,资金和技术则是其次.所以企业内部科学的全面的人力资源管理也因此处在了十分重要的位置上. 现在的人力资源是服务于 ...
- 快速上手virtualenv
五分钟轻松学会管理项目开发环境. 在开发Python应用程序的时候,系统安装的Python3只有一个版本:3.x.所有第三方的包都会被pip安装到Python3的site-packages目录下. p ...
- JAVA入门[4]-IntelliJ IDEA配置Tomcat
一.新建Maven Module测试站点 \ 二.配置Application Server 1.File->Setting,打开设置面板: 2.选中Application Servers,点击+ ...