初探盒模型

原文链接:http://learn.shayhowe.com/html-css/opening-the-box-model/

本篇文章为上述链接文章的一些阅读笔记和心得。也是周计划交付物的一部分。

文章的核心内容是介绍css中非常重要的盒模型概念,来回答“网页元素是如何表示在页面上”这样一个问题。
为了回答这个问题,在学习盒模型前需要了解css的一个属性display

display

每个元素都有一个默认的display属性,根据元素类型的不同默认值也不同,常见的display属性有block,inline,inline-block,none
块级元素的默认值为block, 内联元素的默认值为inline. 其中block将使该元素成为块级元素,inline将使该元素成为内联元素。
当使用inline-block时,该元素就像块级元素一样将接受所有盒模型的属性,但是又可以和其它元素一起共占一行。
使用none时,该元素将彻底消失在页面中,并且不占任何空位,就像不存在一样。

盒模型

重点中的重点 页面上的每个元素都是矩形
css中有一系列的属性来决定一个矩形元素的尺寸。 通常有以下几个元素决定: display, width, height, padding, border, margin.

一个元素宽度可以由以下公式计算

margin-right + border-right + padding-right + width + padding-left + border-left + margin-left

高度计算公式如下:

margin-top + border-top + padding-top + height + padding-bottom + border-bottom + margin-bottom

下面将简单介绍各个属性:

width && height

width的默认值取决于display的属性,如果时块级元素,那么width将默认为100%,占据整行的宽度。Inline和inline-block元素如果在一行中放不下会被挤到下一行中。内联元素是不能有固定尺寸的,width和height只作用于非内联元素。
height的默认值是由内容本身决定的。

margin

margin属性为环绕某元素的周围空间。它使得元素之间保持一个优雅的距离。需要注意的是margin的top和bottom不被内联元素接受。

padding

padding属性和margin类似,但是它在元素的border内部而不像margin一样在外部。padding的top和bottom能够被内联元素使用,但是可能会溢出到元素的外部。

margin和padding的声明

div {
margin: 20px; #四个属性都是20px
margin: 10px 20px; #top和bottom为10px,left和right为20px
margin: 10px 20px 0 15px; #从top开始顺时针旋转设置四个属性 
margin-top: 10px; #只设置top属性
}

border

border在margin和padding之间,给元素提供一个边框。border属性需要三个值,width,style和color。使用长表达式为 border-width, border-style, border-color.
举个短表达式的例子:

div {
border: 6px solid #923233;
}

同时也可以只允许某个方向出现border,border-bottom可以只显示底部的border。

另一种布局方式 Box sizing

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 各种纯css图标 CSS3可以实现很多漂亮的图形,我收集了32种图形,在下面列出。直接用CSS3画出这些图形,要比...
    剑残阅读 9,768评论 0 8
  • 不会用代码框,所以看着有些乱套,,,,html部分 <!DOCTYPE html> 迅雷看看 ...
    这就是个帅气的名字阅读 1,590评论 0 0
  • CSS假定每个元素都会生成一个或者多个矩形框,这称为元素框(规范的将来版本可能允许非矩形框,不过对现在来说,框都是...
    四光年阅读 858评论 0 10
  • 内容概述 一. 盒子模型 理解盒子模型:4个基本属性 content padding border margin ...
    反复练习的阿离很笨吧阅读 532评论 0 0
  • •前端面试题汇总 一、HTML和CSS 21 你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么? ...
    Simon_s阅读 2,241评论 0 8