盒子模型

盒子模型

网页中一切皆盒子

盒子

  • CSS处理网页时,它认为每个元素都包含在一个不可见的盒子里面
  • 如果把所有的元素都想象成盒子,那么我们对于网页的布局就相当于摆放盒子
  • 我们只需要将相应的盒子拜访在网页中相应的位置即可完成网页的布局

盒子模型

  • 组成内容
    1、内容区(content)
    2、内边距(padding)
    3、边框(border)
    4、外边距(margin)

内容区

  • 指盒子中放置内容的区域,也就是元素中的文本内容,子元素都是存在于内容区中
  • 如果没有为元素设置为内边距和边框,则内容区的大小默认和盒子大小一致的
  • 通过width和height两个属性可以设置内容区的大小
  • width和heigth属性只适用于块元素

内边距

  • 即元素内容与边框以内的空间
    默认情况下width和heigth不包含padding的大小
  • 使用padding属性来设置元素的内边距
  • 内边距(padding),指的是盒子的内容区与盒子边框之间的距离,一共有四个方向:
    padding-top
    padding-right
    padding-bottom
    padding-left
  • 内边距会影响盒子的可见框的大小,元素的背景会延伸到内边距
    盒子的大小由内容区、内边距和边框共同决定

盒子可见框的宽度 = border-left-width + padding-left + width + padding-right + border-right-width
盒子可见框的高度 = border-top-width + padding-top + height + padding-bottom + border-bottom-width

padding:10px 20px 30px 40px; 这样会设置元素的上、右、下、左四个方向的内边距
padding:10px 20px 30px; 分别制定上、左右、下四个方向的内边距
padding:10px 20px;分别指定上下、左右四个方向的内边距
padding:10px;同时指定上左下右四个方向的内边距

边框

  • 可以在元素周围创建边框,边框是元素可见框的最外部
  • 可以使用border属性来设置盒子边框
border:1px red soild; 分别指定了边框的宽度、颜色和样式
  • 和padding一样,默认的width和height并包括边框的宽度
  • 设置边框
    大部分的浏览器中,边框的宽度和颜色都是有默认值,而边框的样式默认值都是none
  • 边框的简写样式,通过它可以同时设置四个边框的样式,宽度,颜色
  • 而且没有任何的顺序要求
    border一指定就是同时指定四个边不能分别指定border-top border-right border-bottom border-left
  • 可以单独设置四个边的样式,规则和border一样,只不过它只对一个边生效
  • 边框样式
语法 说明
none 没有边框
dotted 点线
dashed 虚线
solid 实线
double 双线
groove 槽线
ridge 脊线
insert 凹边
outset 凸边

外边距

  • 外边距是元素边框与周围元素相距的空间
  • 使用margin属性可以设置外边距
  • 用法和padding类型,同样也提供四个方向的margin-top/right/bottom/left
  • 当将左右外边距设置为auto时,浏览器会将左右外边距设置为相等,所以margin:0 auto;可以使元素水平居中
  • 外边距指的是当前盒子与其他盒子之间的距离,他不会影响可见框的大小,而是会影响到盒子的位置
  • 外边距也可以指定为一个负值,如果外边距设置的是负值,则元素会向反方向移动
  • margin还可以设置为auto,auto一般只设置给水平方向的margin
    如果只指定,左外边距或右外边距的margin为auto则会将外边距设置为最大值垂直方向外边距如果设置为auto,则外边距默认就是0如果将left和right同时设置为auto,则会将两侧的外边距设置为相同的值,就可以使元素自动在父元素中居中所以我们经常将左右外边距设置为auto,以使子元素在父元素中水平居中
  • 外边距重叠
  • 垂直外边距的重叠在网页中相邻的垂直方向的外边距会发生外边距的重叠
  • 所谓的外边距重叠指兄弟元素之间的相邻外边距会取最大值而不是取和
  • 如果父子元素的垂直外边距相邻了,则子元素的外边距会设置给父元素

浏览器默认样式

浏览器为了在页面中没有样式时,也可以有一个比较好的显示效果,所以为很多的元素都设置了一些默认的margin和padding,而它的这些默认样式,正常情况下我们是不需要使用的。
所以我们往往在编写样式之前需要将浏览器中的默认的margin和padding统统的去掉

*{
            margin: 0;
            padding: 0;
        }

display

  • 我们不能为行内元素设置width、height、margin-top和margin-bottom
  • 我们可以修改display来修改元素的性质
  • block:设置元素为块元素
  • inline:设置元素为行内元素
  • inline-block:设置元素为行内块元素
  • none:隐藏元素(元素将在页码中完全消失)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,496评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,407评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,632评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,180评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,198评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,165评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,052评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,910评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,324评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,542评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,711评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,424评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,017评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,668评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,823评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,722评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,611评论 2 353

推荐阅读更多精彩内容

  • 什么是盒子? CSS处理网页时,它认为每个元素都包含在一 个不可见的盒子里。 我们只需要将相应的盒子摆放到网页中相...
    咻咻咻滴赵大妞阅读 918评论 0 0
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,748评论 1 92
  • 引言 这次给大家带来了CSS-盒子模型部分的笔记,大家一同交流😊 认识盒子模型之前,先来了解一下CSS元素的分类吧...
    zhaolion阅读 4,305评论 9 85
  • 写作文的时候,如果选题是一个大问题,特别是写日记之类的自由选题的时候。 这时候要区分一点的是作文与事实的区别。 作...
    木工司马阅读 389评论 0 3
  • 比起高考,我更愿意称它为“没有校服的夏天。” “数学真他妈难,语文也是胡写的,出题老师真他妈傻逼。”我接到了荣狗子...
    mimoo_杨喵喵阅读 281评论 0 0