CSS盒模型深入理解

前言

所有文档元素都生成一个矩形框,这称为元素框(element box),它描述了一个元素在文档布局中所占的空间大小。而且,每个框影响着其他元素框的位置和大小

宽高

宽度width被定义为从左内边界到右内边界的距离,高度height被定义为从上内边界到下内边界的距离

在CSS中,可以对任何块级元素设置显式高度。如果指定高度大于显示内容所需高度,多余的高度会产生一个视觉效果,就好像有额外的内边距一样;如果指定高度小于显示内容所需高度,则会向元素添加一个滚动条。如果元素内容的高度大于元素框的高度,浏览器的具体行为取决于overflow属性

[注意]宽度和高度无法应用到行内非替换元素,且不能为负

【auto】
宽高和margin可以设置auto。

对于块级元素来说,宽度设置为auto,则会尽可能的宽。

元素宽度=包含块宽度—元素水平外边距-元素水平边距宽度-元素水平内边距;

高度设置为auto,则会尽可能的窄。详细来说,元素高度=恰好足以包含其内联内容的高度

[注意]如果没有显式声明包含块的height,则元素的百分数高度会重置为auto

【怪异盒模型】
IE6-浏览器的宽高定义的是可见元素框的尺寸,而不是元素框的内容区尺寸

【最大最小宽高】
设置最大最小宽高的好处是可以相对安全地混合使用不同的单位。使用百分数大小的同时,也可以设置基于长度的限制

min-width | min-height
值: <length> | <percentage> | inherit
初始值: 0
应用于: 块级元素和替换元素
继承性: 无
百分数: 相对于包含块的宽度(高度)

max-width | max-height
值: <length> | <percentage> | inherit
初始值: none
应用于: 块级元素和替换元素
继承性: 无
百分数: 相对于包含块的宽度(高度)

[注意]IE6-浏览器不支持min-width | min-height | max-width | max-height
[注意]当最小宽度(高度)大于最大宽度(高度)时,以最小宽高的值为准

内边距

相比于盒模型的其他属性(如在定位中经常使用负值的margin,因为CSS3的到来重获光彩的border等),padding显得中规中矩了很多,没有什么兼容性,也没有一些特殊的问题

对于行内元素,左内边距应用到元素的开始处,右内边距应用到元素的结尾处,垂直内边距不影响行高,但会影响自身尺寸,加背景颜色可以看出

[注意]内边距不能是负值

padding
值:[<length> | <percentage>]{1,4} | inherit
初始值: 未定义
应用于: 所有元素
继承性: 无
百分数: 相对于包含块的width

【50%】
块级元素通过padding:50%可以实现正方形的效果,因为水平和垂直padding的百分比值都是相对于包含块的宽度决定的,常常用于移动端头图

如果是内联元素使用padding:50%,必须配合font-size:0,因为使用inline元素的垂直padding会出现"幽灵空白节点",也就是规范中"strut"。所以通过font-size:0使其尺寸为0

效果展示:
块元素

行内元素:选择font-size = 0; 去除“幽灵空白节点”

【表单】
1、所有浏览器input/textarea/button都内置padding
2、部分浏览器select下拉内置padding,firefox、IE8+可以设置padding
3、除IE10-以外的其他浏览器,radio/checkbox单选复选框无内置padding,且无法设置padding。IE10-浏览器的radio/checkbox单选复选框有内置padding,且可以设置padding
[注意]除IE10-以外的其他浏览器,radio/checkbox单选复选框无内置border,且无法设置border

【button兼容】
1、在firefox浏览器中,设置padding:0,按钮左右两侧依然有padding,这时需要使用firefox自有样式

button::-moz-focus-inner{padding:0;}

2、IE7-浏览器下文字越多,左右padding逐渐变大,设置overflow:visible可解决该问题

3、button按钮的padding与高度计算不兼容

button{
    line-height:20px;
    padding:10px;
    border:none;
}

//结果为:
IE7: 45px
firefox:42px
chrome/IE8+:40px

可以使用label标签来实现类似的效果,然后把按钮button进行可访问性隐藏即可

<button id="btn"></button>
<label for="btn">按钮</label>

label{
    display:inline-block;
    line-height:20px;
    padding:10px;
    border:none;
}

//结果为:
IE7: 40px
firefox:40px
IE8+:40px
chrome:40px

外边距

设置外边距margin会在元素外创建额外的空白,空白通常指不能放其他元素的区域,而且在这个区域中可以看到父元素的背景

外边距可以应用到行内元素,上下外边距对行高没有任何影响。由于上下外边距实际上是透明的,所以这个声明没有任何视觉效果。左外边距应用到元素开始处;右外边距应用到元素结束处

margin
值:[<length> | <percentage> | auto]{1,4} | inherit
初始值: 未定义
应用于: 所有元素
继承性: 无
百分数: 相对于包含块的width

[注意]对于普通元素来说,包含块就是块级父级元素,对于定位元素来说,包含块是定位父级。所以,普通元素的margin百分比相对于块级父级元素的width,定位元素的margin百分比相对于定位父级的width

[注意]margin负值的作用非常大

边框

元素外边距内就是元素的边框border,元素的边框是围绕元素内容的内边距的一条或多条线。边框由粗细、样式和颜色三部分组成

对于行内元素来说,边框实际上画在各行之外的下一个像素上,由于各行紧挨着,所以其边框会重叠。无论为行内元素的边框设置怎样的宽度,不会对行高有任何影响;但左右边框会分别显示在元素的开始处和结尾处

.d1{
    width: 200px;
    border: 1px solid red;
}
.s1{
    border: 1px solid black;
    background-color: yellow;
    padding: 6px;
    margin: 6px;
    font-size: 30px;
    line-height: 50px;
}

<div class="d1"><span class="s1">测试文字测试文字测试文字</span></div>

.d1{
width: 200px;
border: 1px solid red;
}
.s1{
border: 1px solid black;
background-color: yellow;
padding: 6px;
margin: 6px;
font-size: 30px;
line-height: 50px;
}

测试文字测试文字测试文字

box-sizing

在CSS中盒模型被分为两种,第一种是W3C的标准模型,第二种是IE怪异盒模型。

不同之处在于后者的宽高定义的是可见元素框的尺寸,而不是元素框的内容区尺寸。目前对于浏览器大多数元素都是基于W3C标准的盒模型,但对于表单form中的部分元素还是基于IE的怪异盒模型,如input里的radio、checkbox、button等元素,如果给其设置border和padding它们也只会往元素盒内延伸

在W3C的标准模型下,宽度和高度仅仅包含了内容宽度,除去了边框和内边距两个区域,这样为web设计师处理效果带来了不少麻烦。为了解决这个问题,CSS3新增了一个盒模型属性box-sizing,能够事先定义盒模型的尺寸解析方式

[注意]IE7-浏览器不支持

box-sizing
值: content-box | border-box | padding-box | inherit
初始值: content-box
应用于: 块级元素和替换元素
继承性: 无

[注意1]只有firefox浏览器支持padding-box属性值
[注意2]IE浏览器在getComputedStyle得到width/height是按照标准模式计算的,而不论box-sizing的取值

效果展示:

原文地址:https://www.cnblogs.com/shiyou00/p/10640765.html

时间: 2024-10-08 09:58:45

CSS盒模型深入理解的相关文章

CSS盒模型重新理解篇

最近比较闲,思索着怎么提高下JS技术,于是找到了昵称为豪情的这哥们的一篇文章,应该是哥们吧,详细了解了下,发现其中的试题CSS部分有些做起来很吃力,于是乎各种google恶补盒模型,找到了这哥们的一文章<纯CSS无hacks的跨游览器多列布局>,应该是算是中文版吧,翻译辛苦了,这个是原文出处equal height columns article.重新理解了下盒模型.以前出现的等高布局是通过JS来进行解决的,看来CSS还是没吃透,这回算是彻底悟透了.各种布局尽管来吧,在被前端搞中不断提升.:D

对css盒模型的理解

介绍一下标准css的盒子模型?低版本IE的盒子模型有什么不同的? 1.有两种:IE盒子模型(怪异模式).W3c盒子模型(标准模式). 2.盒模型组成:内容(content).填充(padding).边界(margin).边框(border).3.区别:IE的content部分把border和padding计算了进去 应用场景: (1)表单:表单中有一些input元素其实还是展现的是传统IE盒模型,带有一些默认的样式,而且在不同平台或者浏览器下的表现不一,造成了表单展现的差异.此时我们可以通过bo

前段--尝试以新角度深入理解CSS盒模型(1)

CSS样式规则的学习是很繁琐和枯燥的,因为它不像物理.数学或者其他编程语言一样有一些基本概念.有一些基本公理或者规则,其他所有的表现都是概念在这些公里或者规则之下的逻辑游戏,CSS是有一些基本概念,但它没有说给你几条规则然后所有的表现都是在这些规则之下的任意自由组合,你要推测一个样式声明块的在页面中具体是怎样表现的,你几乎靠非常少逻辑推理去推测出来,绝大多数是你知道并记住了这种写法的声名块是具有怎样的表现的.之所以为这样也是因为样式的组合太繁琐组合情况特别多,像同样的概念margin在块级中的表

理解CSS盒模型

CSS盒模型是CSS可视化格式化系统的基石,它是理解样式表如何工作的核心概念,盒模型可以用于元素定位和网页布局.内边距padding是内容区和边框border之间的区域,元素盒在页面上占据的总宽度是左边的外边缘到右边的外边缘之间的距离.使用width和height属性可以设置块级元素或内嵌可替换元素的大小.外边距margin是围绕在元素边框之外的可选区域.正常文档中的相邻块级元素的垂直外边距将会重合,即,相邻的两个块级元素之间的空白将会是两个元素的外边距中较大的那一个,而不是两个外边距的和.边框

CSS盒模型 理解

每个元素(块级和内嵌)都会有个矩形盒子,这个盒子为元素盒,盒子的中间(center)为元素的内 容,center区域内的距离为元素的高度(height).宽度(width).在盒模型中 padding就是内容 (center)与边框(border)的空隙区域,而margin 则是边框(border)外的空隙区域.元素的背景颜 色和背景图像在内边框(padding)区域是可见的,并且延生到border下面:元素的外边框(maegin)区 域总是透明的,所有父级元素的背景能看见. 盒内距离表示例如:

深入理解CSS盒模型

如果你在面试的时候面试官让你谈谈对盒模型的理解,你是不是不知从何谈起.这种看似简单的题其实是最不好答的. 下面本文章将会从以下几个方面谈谈盒模型. 基本概念:标准模型 和IE模型 CSS如何设置这两种模型 JS如何设置获取盒模型对应的宽和高 实例题(根据盒模型解释边距重叠) BFC(边距重叠解决方案) 基本概念 盒模型的组成大家肯定都懂,由里向外content,padding,border,margin. 盒模型是有两种标准的,一个是标准模型,一个是IE模型. 从上面两图不难看出在标准模型中,盒

css盒模型和块级、行内元素深入理解

一.CSS盒模型 盒模型概述 盒模型是CSS的核心知识点之一,它指定元素如何显示以及如何相互交互.页面上的每个元素都被看成一个矩形框,这个框由元素的内容.内边距.边框和外边距组成.如下图所示: 内边距出现在内容区域的周围.如果在元素上添加背景,那么背景应用于元素的内容和内边距组成的区域.因此可以用内边距在内容周围创建一个隔离带,使内容不与背景混合在一起.添加边框会在内边距区域外边增加一条线.这些线可以有不同的样式和宽度,如实线.虚线.点画线.在边框外边的是外边距,外边距是透明的,一般使用它控制元

css盒模型

css盒子模型是为了让我们充分理解div+css模型的定位功能,盒子模型在学习div+css布局方式中必须要学习的一个模型. 那什么是css盒模型呢? 网页设计中常听到的属性名:内容(content).填充(padding).边框(border).边界(margin).css盒模型都具备这些属性.这些属性和日常生活中盒子的属性是一样的.内容就是盒子里面装的东西,而填充就是像盒子里装的一些反震的材料,边框就是箱子的本身,边界呢就像盒子之间的空隙. 盒子的模型有2种,分别是IE盒子模型和标准盒子模型

CSS盒模型(Box Model)

阅读目录 1. 什么是CSS盒模型 2. IE盒模型和W3C盒模型 3. CSS3属性box-sizing 4. 关于盒模型的使用 在最初接触CSS的时候,对于CSS盒模型的不了解,撞了很多次的南墙呀.盒模型是网页布局的基础,它制定了元素如何在页面中显示,如果足够地掌握,那使用CSS布局那将会容易得多. 1. 什么是CSS盒模型 盒模型,顾名思义,就是一个盒子.生活中的盒子,有长宽高,盒子本身也有厚度,可以用来装东西.页面上的盒模型我们可以理解为,从盒子顶部俯视所得的一个平面图,盒子里装的东西,