一只特立独行的猿

做一个思想上与行动上的巨人

CSS 盒子模型(上)(20160819-0019)

CSS 框模型规定了元素框处理元素内容、内边距、边框、外边距的方式。

CSS 框模型概述


元素框的最内部分是实际的内容,直接包围内容的是内边距;内边距呈现了元素的背景,内边距的边缘是边框;边框以外是外边距,外边距默认是透明的,因此不会遮挡其后的任何元素。提示:背景应用于内容和内边距、边框组成的区域。内边距、边框和外边距都是可选的,默认值是零。可以将元素的 margin 和 padding 设置为零来覆盖默认的浏览样式。

一、元素尺寸

CSS 盒子模型中基础的就是设置一个元素的尺寸大小。有三组样式来配置一个元素的尺寸大小,样式表:

属性 说明 CSS 版本
width auto、长度值或百分比 设置元素的宽度 1
height auto、长度值或百分比 设置元素的高度 1
min-width auto、长度值或百分比 设置元素的最小宽度 2
min-height auto、长度值或百分比 设置元素的最小高度 2
max-width auto、长度值或百分比 设置元素的最大宽度 2
max-height auto、长度值或百分比 设置元素的最大高度 2
<div id="first"> 这是一个段落,this is a paragraph. 这是一个段落,this is a paragraph. 这是一个段落,this is a paragraph. 这是一个段落,this is a paragraph. 这是一个段落,this is a paragraph. 这是一个段落,this is a paragraph. 这是一个段落,this is a paragraph. 这是一个段落,this is a paragraph. 这是一个段落,this is a paragraph. </div>

<br>
<div id="a">
	<div id="b"> 这是一个段落,this is a paragraph.这是一个段落,this is a paragraph.这是一个段落,this is a paragraph. </div>
</div>
/* 设置背景颜色方便观察 */
div{
	background-color: silver;
}

/* 设置元素尺寸。用于设置元素的固定尺寸 */
#first{
	/*width: 200px;
	height: 200px;*/
}

/* 限制元素的尺寸。这一组主要是应对可能动态产生元素尺寸变大表小的问题,从而限制它最大和最小 */
#first{
	/*min-width: 100px;
	min-height: 100px;
	max-width: 300px;
	max-width: 300px;*/
}

/* auto 自适应。auto 是默认值,width 在 auto 下是100%的值;height 在 auto 下是自适应 */
#first{
	width: auto;
	height: auto;
}

/* 百分比。百分比是相对于父元素长度来衡定的。 */
#a{
	width: 200px;
	height: 200px;
}

#b{
	background-color:gray;
	width: 80%;
	height: 80%;
}
二、元素内边距

CSS 盒模型中可以设置元素内部边缘填充空白的大小,称之为内边距。样式表:

属性 说明 CSS 版本
padding-top 长度值或百分比 设置顶部内边距 1
padding-bottom 长度值或百分比 设置底部内边距 1
padding-left 长度值或百分比 设置左边内边距 1
padding-right 长度值或百分比 设置右边内边距 1
padding 1~4个长度值或百分比 简写属性 1

/* 设置四个内边距 */
#first{
	/*padding-top: 30px;
	padding-right: 50px;
	padding-bottom: 60px;
	padding-left: 40px;*/
}

/* 简写形式,分别对应上内边距、右内边距、下内边距、左内边距*/
#first{
	/*padding: 30px 50px 60px 40px;*/
}

/* 简写形式,分别对应上内边距、左右内边距、下内边距*/
#first{
	/*padding: 30px 40px 50px;*/
}

/* 简写形式,分别对应上下内边距、左右边内边距*/
#first{
	/*padding: 30px 50px;*/
}

/* 简写形式,分别对应上下左右内边距*/
#first{
	/*padding: 30px;*/
}
三、元素外边距

CSS 盒模型中可以设置元素外部边缘填充空白的大小,称之为外边距。样式表:

属性 说明 CSS 版本
margin-top 长度值或百分比 设置顶部外边距 1
margin-bottom 长度值或百分比 设置底部外边距 1
margin-left 长度值或百分比 设置左边外边距 1
margin-right 长度值或百分比 设置右边外边距 1
margin 1~4个长度值或百分比 简写属性 1
/* 设置四个外边距 */
#first{
/*	margin-top: 20px;
	margin-right: 30px;
	margin-bottom: 40px;
	margin-left: 50px;*/
}
/* 简写形式,分别为上、右、下、左*/
#first{
	/*margin: 20px 30px 40px 50px;*/
}
/* 简写形式,分别为上、左右、下 */
#first{
	/*margin: 20px 30px 40px;*/
}
/* 简写形式,分别为上下、左右 */
#first{
	margin: 20px 30px;
}
/* 简写形式,为上下左右 */
#first{
	margin: 30px;
}
四、处理溢出

当设置了元素固定尺寸且内容过大时,就会出现溢出的问题。溢出主要朝两个方向:右侧和底部。可以通过 overflow 系列样式来控制它。

属性 说明 CSS 版本
overflow-x 溢出值 设置水平方向的溢出 3
overflow-y 溢出值 设置垂直方向的溢出 3
overflow 溢出值 简写属性 2

溢出处理主要有四种处理值:

说明
auto 浏览器自动处理溢出内容。如果有溢出内容,就显示滚动条,否则就不显示滚动条
hidden 如果有溢出的内容,直接剪掉
scroll 不管是否溢出,都会出现滚动条。不同平台和浏览器显示方式不同
visible 默认值,不管是否溢出,都显示内容

#first{
	width: 200px;
	height: 200px;
}

/* 设置溢出为 auto */
#first{
	overflow:auto;
}



示例代码地址
阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u010494204/article/details/52350711
个人分类: HTML5
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

CSS 盒子模型(上)(20160819-0019)

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭