一、什么是盒子模型

盒子模型是css中一个重要的概念,理解了盒子模型才能更好的排版。

从上图可以看到标准的盒子模型范围包括margin(外边距)、border(边框)、padding(内边距)、content(网页内容)。
网页内容就是盒子里面装的东西。在网页设计中,内容常指文字、图片等元素。
内边距(PADDING)可以理解为盒子里装的东西和边框的距离。
边框(BORDER)就是盒子本身。
外边距(MARGIN)就是边框外面自动留出的一段空白。

注意:

每个HTML元素都可以看做是一个盒子。

1、外边距(margin)

2、边框(border)

3、内边距(padding)

4、小结

4、1 盒子模型总尺度
盒子模型总尺度=margin*2+border*2+padding*2+内容尺寸(宽/高)。

例如、一个盒子的margin为25px,border为2px,padding为10px,content的宽为200px、高为50px,假如用标准盒子模型解释,那么这个盒子需要占据的位置为:宽25*2+2*2+10*2+200=274px、高25*2+2*2*10*2+50=124px,盒子的实际大小为:宽 2*2+10*2+200=224px、高 2*2+10*2+50=74px;

4、2 外边距可以用于设置网页水平居中
margin-left:auto;
margin-right:auto;
例如:margin 0px auto;

4、3 块元素才能完全适用于盒子模型
使用display属性来相互转化
none:元素隐藏,不可见,不占据空间。
visibility:hidden 元素隐藏,但是占据空间。
block:转为块元素,独占一行。
inline:转为内联元素,不换行。
inline-block:行内块元素。

下面的例子演示如何将行内元素转换为块级元素。

例如:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>块级元素</title>
<style type="text/css">
.div-style a{
width: 500px;
border: 1px solid red;
margin: 0 10px;
}
</style>
</head>
<body>
<div class="div-style">
<p>
<a>超链接1</a>
<a>超链接2</a>
</p>
</div> </body>
</html>

效果:

因为<a>标签是行级元素,所以设置的width属性对<a>标签不起作用。下面使用display属性进行转换:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>块级元素</title>
<style type="text/css">
.div-style a{
display: block;/*将行级元素转换为块级元素*/
width: 500px;
border: 1px solid red;
margin: 10px;
}
</style>
</head>
<body>
<div class="div-style">
<p>
<a>超链接1</a>
<a>超链接2</a>
</p>
</div>
</body>
</html>

效果:

下面的例子演示如何将块级元素转换为行级元素,先看下面的例子:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>块级元素</title>
<style type="text/css">
/* .div-style a{
display: block;/*将行级元素转换为块级元素*/
/* width: 500px;
border: 1px solid red;
margin: 10px;
} */
.div-style p{
width: 500px;
border: 1px solid red;
margin: 10px;
}
</style>
</head>
<body>
<div class="div-style">
<p>
<a>超链接1</a>
<a>超链接2</a>
</p>
<p>
<a>超链接3</a>
<a>超链接4</a>
</p>
</div> </body>
</html>

效果:

因为<p>标签是块级元素,所以两个<p>标签会分两行显示。

在看下面的例子:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>块级元素</title>
<style type="text/css">
/* .div-style a{
display: block;/*将行级元素转换为块级元素*/
/* width: 500px;
border: 1px solid red;
margin: 10px;
} */
.div-style p{
display: inline;/*inline表示将块级元素转换成行级元素*/
/* width: 500px; */ /*因为对行级元素设置width属性无效,所以这里去掉width属性*/
border: 1px solid red;
margin: 10px;
}
</style>
</head>
<body>
<div class="div-style">
<p>
<a>超链接1</a>
<a>超链接2</a>
</p>
<p>
<a>超链接3</a>
<a>超链接4</a>
</p>
</div> </body>
</html>

效果:

这是两个<p>标签会在一行显示。

下面演示display的none属性,先看下面的代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>display的none属性</title>
</head>
<body>
<div>我是第一个DIV</div>
<p>我是p段落</p>
<div>我是第二个DIV</div>
</body>
</html>

效果:

在看下面的代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>display的none属性</title>
<style type="text/css">
p{
display: none;/*设置p标签隐藏*/
}
</style>
</head>
<body>
<div>我是第一个DIV</div>
<p>我是p段落</p>
<div>我是第二个DIV</div>
</body>
</html>

效果:

从上面的截图中可以看出:display的none属性可以使元素隐藏,并且隐藏的元素不占据空间。

下面在看看visibility属性:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>display的none属性</title>
<style type="text/css">
/* p{
display: none;/*设置p标签隐藏*/
/* } */
p{
visibility: hidden;
}
</style>
</head>
<body>
<div>我是第一个DIV</div>
<p>我是p段落</p>
<div>我是第二个DIV</div>
</body>
</html>

效果:

从上面的截图中可以看出:visibility属性也可以将元素隐藏,但是会占据元素原来的空间。

在看inline-block属性。

先看下面的例子:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>line-block属性</title>
<style type="text/css">
.div-style a{
display: block;
width: 500px;
border: 1px solid red;
margin: 10px;
}
</style>
</head>
<body>
<div class="div-style">
<p>我是第一个段落
<a>超链接1</a>
<a>超链接2</a>
</p>
<p>我是第二个段落
<a>超链接3</a>
<a>超链接4</a>
</p>
</div>
</body>
</html>

效果:

从截图中可以看出:<a>标签可以设置宽度了,而且是单独占一行显示,那么能不能让<a>标签既能设置宽度又能在一行显示呢?答案是肯定的,看下面的代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>line-block属性</title>
<style type="text/css">
.div-style a{
display: inline-block;
width: 300px;
border: 1px solid red;
margin: 10px;
}
</style>
</head>
<body>
<div class="div-style">
<p>我是第一个段落
<a>超链接1</a>
<a>超链接2</a>
</p>
<p>我是第二个段落
<a>超链接3</a>
<a>超链接4</a>
</p>
</div>
</body>
</html>

效果:

使用display:inline-block属性就可以使<a>标签既能设置宽度,又能在一行显示了。

盒子模型的示例:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>盒子模型</title>
<style type="text/css">
*{
margin: 0px;
padding: 0px;
}
.main{
width: 300px;
height: 160px;
border: 1px solid #3a6587;
margin:0 auto;
padding: 0 auto;
}
div h3{
color: white;
background-color: gray;
padding-left: 20px;
height: 30px;
line-height: 30px;/*垂直居中显示*/
}
.td-left{
text-align: right;
}
.bottom{
margin:20px 10px;
}
</style>
</head>
<body>
<div class="main">
<div class="top">
<h3>会员登录</h3>
</div>
<div class="bottom">
<table cellspacint="0" cellpadding="0">
<tr>
<td class="td-left">姓名:</td>
<td><input type="text"></td>
</tr>
<tr>
<td class="td-left">邮箱:</td>
<td><input type="text"></td>
</tr>
<tr>
<td class="td-left">联系电话:</td>
<td><input type="text"></td>
</tr>
<tr>
<td class="td-left"></td>
<td><input type="submit" value="登录"></td>
</tr>
</table>
</div>
</div>
</body>
</html>

效果:

CSS(六):盒子模型的更多相关文章

  1. 深入理解CSS系列(一):理解CSS的盒子模型

    接触前端也有好几个年头了,但是,讲实话,对于CSS的理解真的是不敢恭维,相信很多同行也有类似的感受吧!这是为什么呢?因为我们都认为CSS太简单了,没有必要深入学习,果真如此?其实,只不过是自己图样图森 ...

  2. 这些HTML、CSS知识点,面试和平时开发都需要 No1-No4(知识点:HTML、CSS、盒子模型、内容布局)

    这些HTML.CSS知识点,面试和平时开发都需要 No1-No4   系列知识点汇总 这些HTML.CSS知识点,面试和平时开发都需要 No1-No4(知识点:HTML.CSS.盒子模型.内容布局) ...

  3. 使用css弹性盒子模型

    提示: 当期内容不充实, 修改后再来看吧 以下称:弹性子元素: 子元素, 弹性容器: 容器 弹性盒子的属性 1. css弹性盒子模型规定了弹性元素如何在弹性容器内展示 2. 弹性元素默认显示在弹性容器 ...

  4. #CSS的盒子模型、元素类型

    CSS的盒子模型.元素类型   本文首先介绍了CSS元素的统一内部结构模型,盒子模型:然后介绍了CSS元素基于不同分类标准定义的元素类型,包括基于不同内容设置方式定义的replaced元素和non-r ...

  5. 深入了解CSS中盒子模型

    CSS中盒子模型介绍 什么是盒子? 盒子是用来存储物品,我们可以将盒子理解为酒盒,酒盒有什么组成的呢? 有酒可以喝.有填充物保护酒防止酒被摔坏.纸盒子. 我们怎么理解CSS中的盒子呢,CSS中盒子有什 ...

  6. CSS 弹性盒子模型

    CSS 弹性盒子模型 https://www.w3.org/TR/2016/CR-css-flexbox-1-20160526/ CSS Flexible Box Layout Module Leve ...

  7. 认识CSS中盒子模型

    前端之HTML,CSS(六) CSS 盒子模型 CSS中的重点,理解盒子模型对于CSS才能有更清晰的认识.网页说简单一点其实就是一块一块的拼接出来的,可以想象成拼图,所有图块拼接在一起就成了一幅图像. ...

  8. css 大话盒子模型

    什么是盒子模型? CSS中, Box Model叫盒子模型(或框模型),Box Model规定了元素框处理元素内容(element content).内边距(padding).边框(border) 和 ...

  9. CSS系列:CSS中盒子模型

    盒子模型是CSS控制页面时一个很重要的概念.所有页面中的元素都可以看成是一个盒子,占据着一定的页面空间.可以通过调整盒子的边框和距离等参数,来调节盒子的位置和大小. 1. 盒子的内部结构 在CSS中, ...

  10. CSS之盒子模型及常见布局

    盒子模型的综合应用 CSS提高1 Div   ul    li 的综合应用很多的网页布局现在都用到这种模式 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTM ...

随机推荐

  1. 关于使用jquery时,ie8下提示对象不支持的属性或方法的解决办法

    转自:http://wapapp.baidu.com/auoong/item/538790fcbe87c834d7ff8cde 首先这个问题的前提是已经排除了常见的这个问题.下面说一种今天我碰到的一种 ...

  2. C++ 踩内存

    1.从上往下,栈在堆上面(记忆方法:站在堆上面),二者向里压缩,也就是说,栈地址减少,堆地址增加.栈顶是小地址. 2.模拟踩内存,让程序崩溃.代码如下: int main(int argc, char ...

  3. css 小问题解决方法整理

    1,图片垂直居中: 设置包括图片的div:height=20px:line-height=20px. 设置图片vertical-align:middle 就可以. 2,行内块元素有3px bug,可通 ...

  4. ipv6相关

    link-local和site-local address http://blog.163.com/s_u/blog/static/13308367201052411431027/ 学习IPV6的时候 ...

  5. uva10401Injured Queen Problem(递推)

    题目:uva10401Injured Queen Problem(递推) 题目大意:依然是在棋盘上放皇后的问题,这些皇后是受伤的皇后,攻击范围缩小了.攻击范围在图中用阴影表示(题目).然后给出棋盘的现 ...

  6. 扩展MSEG 加入Z字段

    append    MSEG append    IMSEG append    BAPI_TE_XMSEG 实现 BADI: MB_BAPI_GOODSMVT_CREATE BAPI中: BAPI_ ...

  7. QtGui.QPen

    The QtGui.QPen is an elementary graphics object. It is used to draw lines, curves and outlines of re ...

  8. Decorator [ˈdekəreɪtə(r)] 修饰器/装饰器 -- 装饰模式

    装饰模式 -- 原先没有,后期添加的属性和方法 修饰器(Decorator)是一个函数,用来修饰类的行为.这是ES7的一个提案,目前Babel转码器已经支持. 需要先安装一个插件: npm insta ...

  9. 37、EnumSet详解

    EnumSet类也是有顺序的,EnumSet按照枚举值在Enum类内定义的顺序决定集合元素的顺序 EnumSet在内部已位向量的形式存储,这种存储方式非常紧凑.搞笑,因此EnumSet占用内存很小,而 ...

  10. Mybatis解决字段名与实体类属性名不相同的冲突

    在平时的开发中,我们表中的字段名和表对应实体类的属性名称不一定都是完全相同的,下面来演示一下这种情况下的如何解决字段名与实体类属性名不相同的冲突. 一.准备演示需要使用的表和数据 CREATE TAB ...