盒子模型(2)

(1)内边距:
内边距(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-top: 100px;
设置右内边距
padding-right: 100px;
padding-bottom: 100px;
padding-left: 100px;

        使用padding可以同时设置四个边框的样式,规则和border-width一致
        
        padding: 100px;
        padding: 100px 200px;
        padding: 100px 200px 300px;
        padding: 100px 200px 300px 400px;
    }
    /*创建一个子元素box2占满box1*/
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>内边距</title>
    <style type="text/css">
        .box1{
            width: 200px;
            height: 200px;
            background: #bfa;
            border: 10px green solid;
            border-top: 100px;
            border-left: 100px;
            border-right: 100px;
            border-bottom: 100px;
            padding: 100px 200px 300px 400px;
        }
        .box2{
            width: 100%;
            height: 100%;
            background: yellow;
        }
    </style>
</head>
<body>
    <div class="box1">
        <div class="box2"></div>
    </div>
</body>
</html>

(2)外边距:
外边距指的是当前盒子与其他盒子之间的距离,他不会影响可见框的大小,而是会影响到盒子的位置
盒子有四个方向的外边距:
margin-top
margin-right
margin-bottom
margin-left
由于页面中的元素都是靠左靠上摆放的,所以注意当我们设置上和左外边距时,会导致盒子自身的位置发生改变,而如果是设置右和下外边距会改变其他盒子的位置

        /*设置上外边距,即盒子的上边框与其他盒子的距离*/
        /*margin-top: 100px;*/
        /*左外边距*/
        /*margin-left: 100px;*/
        /*设置右和下外边距*/
        /*margin-right: 100px;
        margin-bottom: 100px;*/
        /*
        外边距也可以指定为一个负值,如果外边距设置的是负值,则元素会向反方向移动
        */
        /*margin-left: -100px;
        margin-top: -100px;
        margin-bottom: -100px;*/
        /*margin-bottom: -100px;*/
        /*
        margin还可以设置为auto,auto一般只设置给水平方向的margin
        如果只指定,左外边距或右外边距的margin为auto则会将外边距设置为最大值
        垂直方向外边距如果设置为auto,则外边距默认就是0
        如果将left和right同时设置为auto,则会将两侧的外边距设置为相同的值,就可以使元素自动在父元素中居中
        所以我们经常将左右外边距设置为auto,以使子元素在父元素中水平居中
        */
        /*margin-left: auto;
        margin-right: auto;*/
        /*margin-top: auto;*/
        /*
        外边距同样可以使用简写属性 margin,可以同时设置四个方向的外边距,规则和padding一样
        */
        /*margin: 10px 20px 30px 40px;*/
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>外边距</title>
    <style type="text/css">
        .box{
            width: 300px;
            height: 300px;
            background: yellow;
            border: 20px solid red;
            /*margin-top: 100px;
            margin-left: 100px;
            margin-right: 100px;
            margin-bottom: 100px;*/
            margin-top: auto;
        }
        .box1{
            width: 200px;
            height: 200px;
            background: green;
            margin-top: -100px;
            margin-left: -100px;
            margin-right: -100px;
            margin-bottom: -100px;
        }
    </style>
</head>
<body>
    <div class="box"></div>
    <div class="box1"></div>
</body>
</html>

(3)外边距的重叠:
垂直外边距的重叠
在网页中相邻的垂直方向的外边距会发生外边距的重叠
所谓的外边距重叠指兄弟元素之间的相邻外边距会取最大值而不是取和
如果父子元素的垂直外边距相邻了,则子元素的外边距会设置给父元素

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>外边距的重叠</title>
    <style type="text/css">
        /*.box{
            width: 300px;
            height: 300px;
            background: yellow;
            margin-bottom: 100px;
        }
        .box1{
            width: 300px;
            height: 300px;
            background: green;
            margin-top: 100px;
        }*/
        .box3{
            width: 300px;
            height: 300px;
            background: yellow;
            padding: 100px;
        }
        .box4{
            width: 200px;
            height: 200px;
            background: yellowgreen;
            margin-top: 100px;
        }
    </style>
</head>
<body>

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

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>浏览器默认样式</title>
    <style type="text/css">
        *{
            margin: 0;
            margin: 0;
        }
        .box{
            width: 200px;
            height: 200px;
            background: yellow;
        }
        p{
            background: red;
        }
    </style>
</head>
<body>
    <div class="box"></div>
    <p>我是小哥哥</p>
    <p>我是小哥哥</p>
    <p>我是小哥哥</p>
    <p>我是小哥哥</p>
    <ul>
        <li>叫哥哥</li>
        <li>叫哥哥</li>
        <li>叫哥哥</li>
    </ul>
</body>
</html>

(5)内联元素的盒模型:
盒模型分成内容区、内边距 、边框 、外边距四个部分
内联元素不能设置width和height
width: 100px;
height: 100px;
设置水平内边距,内联元素可以设置水平方向的内边距//垂直方向内边距,内联元素可以设置垂直方向内边距,但是不会影响页面的布局
padding-top: 50px;
padding-bottom: 50px;
为元素设置边框,内联元素可以设置边框,但是垂直的边框不会影响到页面的布局水平外边距,内联元素支持水平方向的外边距为右边的元素设置一个左外边距
水平方向的相邻外边距不会重叠,而是求和
margin-left: 100px;
内联元素不支持垂直外边距
margin-top: 200px;
margin-bottom: 200px;

<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>内联元素的盒模型</title>
    <style type="text/css">
        span{
            background: #bfa;
        }
        .box{
            width: 100px;
            height: 100px;
            background: red;
        }
        .s1{
            /*width: 100px;
            height: 100px*/
            padding-left: 50px;
            padding-right: 50px;
            /*padding-top: 50px;
            padding-bottom: 50px;*/
            background: yellow;
            border: 10px orange solid;
            margin-right: 100px;
            margin-left: 100px;
            /*margin-top: 100px;
            margin-bottom: 100px;*/
        }
        .s2{
            margin-left: 200px;
            margin-bottom: 100px;
        }
    </style>
</head>
<body>
    <span class="s1">我是一个span</span>
    <span class="s2">我是一个span</span>
    <span>我是一个span</span>
    <span>我是一个span</span>
    <div class="box"></div>
</body>
</html>

(6)display和visidility:
将一个内联元素变成块元素
通过display样式可以修改元素的类型
可选值:
inline:可以将一个元素作为内联元素显示
block: 可以将一个元素设置块元素显示
inline-block:将一个元素转换为行内块元素
- 可以使一个元素既有行内元素的特点又有块元素的特点,既可以设置宽高,又不会独占一行
none: 不显示元素,并且元素不会在页面中继续占有位置display: none;
使用该方式隐藏的元素,不会在页面中显示,并且不再占据页面的位置

        display: none;
        
         visibility
            - 可以用来设置元素的隐藏和显示的状态
            - 可选值:
                visible 默认值,元素默认会在页面显示
                hidden 元素会隐藏不显示 
          
          使用 visibility:hidden;隐藏的元素虽然不会在页面中显示,
                但是它的位置会依然保持
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>display和visidility</title>
    <style type="text/css">
        .box{
            width: 500px;
            height: 500px;
            background: orange;
            visibility: hidden;
        }
        a{
            background: red;
            display: inline-block;
            display: none;
            width: 500px;
            height: 500px;
        }
    </style>
</head>
<body>
    <div class="box"></div>
    <a href="#">我是大超链接</a>
    <span>hello</span>
</body>
</html>

(7)overflow:
子元素默认是存在于父元素的内容区中,理论上讲子元素的最大可以等于父元素内容区大小
如果子元素的大小超过了父元素的内容区,则超过的大小会在父元素以外的位置显示
超出父元素的内容,我们称为溢出的内容
父元素默认是将溢出内容,在父元素外边显示
通过overflow可以设置父元素如何处理溢出内容:
可选值:
- visible,默认值,不会对溢出内容做处理,元素会在父元素以外的位置显示
- hidden, 溢出的内容,会被修剪,不会显示
- scroll, 会为父元素添加滚动条,通过拖动滚动条来查看完整内容
- 该属性不论内容是否溢出,都会添加水平和垂直双方向的滚动条
- auto,会根据需求自动添加滚动条,需要水平就添加水平,需要垂直就添加垂直,都不需要就都不加

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>overflow</title>
    <style type="text/css">
        .box{
            width: 200px;
            height: 200px;
            background: red;
            overflow: hidden;
            overflow: scroll;
        }
        .box1{
            width: 100px;
            height: 500px;
            background: yellow;
        }
    </style>
</head>
<body>
    <div class="box">
        <div class="box1"></div>
    </body>
</body>
</html>

(8)文档流:
文档流处在网页的最底层,它表示的是一个页面中的位置,我们所创建的元素默认都处在文档流中

元素在文档流中的特点
    块元素
        1.块元素在文档流中会独占一行,块元素会自上向下排列
        2.块元素在文档流中默认宽度是父元素的100%
        3.块元素在文档流中的高度默认被内容撑开
    内联元素
        1.内联元素在文档流中只占自身的大小,会默认从左向右排列,如果一行中不足以容纳所有的内联元素,则换到下一行,继续自左向右。
        2.在文档流中,内联元素的宽度和高度默认都被内容撑开
-->

<!-- 
当元素的宽度的值为auto时,此时指定内边距不会影响可见框的大小,而是会自动修改宽度,以适应内边距
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>文档流</title>
    <style type="text/css">
        
    </style>
</head>
<body>
    <div style="width: 100px; height: 100px;background: red; padding-left: 200px;s"></div>
    <div style="width: 100px; height: 100px;background: yellow;"></div>
    <span style="background: orange;">我是小哥哥</span>
</body>
</html>

(9)浮动:

<head>
    <meta charset="UTF-8">
    <title>浮动</title>
    <style type="text/css">
        .box1{
            width: 600px;
            height: 200px;
            background: red;
            /*display: inline-block;*/
            /*float: left;*/
            float: right;
        }
        .box2{
            width: 600px;
            height: 200px;
            background: yellow;
            /*display: inline-block;*/
            /*float: left;*/
            float: right;
        }
        .box3{
            width: 100px;
            height: 100px;
            background: orange;
            /*display: inline-block;*/
            /*float: left;*/
            float: right;
        }
    </style>
</head>
<body>
    <div class="box1"></div>
    <div class="box2"></div>
    <div class="box3"></div>
</body>
</html>

(10)浮动2:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>浮动2</title>
    <style type="text/css">
        *{
            margin: 0;
            padding: 0;
        }
        .box{
            width: 20px;
            height: 20px;
            background: red;
            float: left;
        }
        .p1{
            /*height: 200px;*/
            background: yellow;
        }
    </style>
</head>
<body>
    <div class="box"></div>
    <p class="p1">谓浮动指的是使元素脱离原来的文本流,在父元素中浮动起来。
浮动使用float属性。
可选值:
none:不浮动
left:向左浮动
right:向右浮动
块级元素和行内元素都可以浮动,当一个行内元素浮动以后将会自动变为一 个块级元素。
当一个块级元素浮动以后,宽度会默认被内容撑开,所以当漂浮一个块级元 素时我们都会为其指定一个宽度。
</p>
</body>
</html>

(11)浮动3:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>浮动3</title>
    <style type="text/css">
        .box{
            height: 100px;
            background: yellow;
            float: left;
        }
        .s1{
            float: left;
            width: 100px;
            height: 100px;
            background: red;
        }
    </style>
</head>
<body>
    <div class="box">a</div>
    <span class="s1">hello</span>
</body>
</html>

(12)简单布局:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>简单布局</title>
    <style type="text/css">
    *{
        margin: 0;
        padding: 0;
    }
        .header{
            width: 1000px;
            height: 50px;
            background: red;
            margin: 0 auto;
        }
        .content{
            width: 1000px;
            height: 400px;
            background: orange;
            margin: 0 auto;
        }
        .footer{
            width: 1000px;
            height: 100px;
            background: green;
            margin: 0 auto;
        }
        .left{
            width: 300px;
            height: 100%;
            background: yellow;
            float: left;
        }
        .center{
            width: 380px;
            height: 100%;
            background: blue;
            float: left;
        }
        .ringt{
            width: 300px;
            height: 100%;
            background: pink;
            float: left;
        }
    </style>
</head>
<body>
    <div class="header"></div>
    <br>
    <div class="content">
        <div class="left"></div>
        <div class="center"></div>
        <div class="ringt"></div>
    </div>
    <br>
    <div class="footer"></div>
</body>
</html>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,727评论 1 92
  • 学会使用CSS选择器熟记CSS样式和外观属性熟练掌握CSS各种选择器熟练掌握CSS各种选择器熟练掌握CSS三种显示...
    七彩小鹿阅读 6,304评论 2 66
  • 引言 这次给大家带来了CSS-盒子模型部分的笔记,大家一同交流😊 认识盒子模型之前,先来了解一下CSS元素的分类吧...
    zhaolion阅读 4,294评论 9 85
  • 1.在什么场景下会出现外边距合并?如何合并?如何不让相邻元素外边距合并?给个父子外边距合并的范例 概念:在CSS当...
    饥人谷_任磊阅读 641评论 0 3
  • 突想起然席勒说过一句话‘时间的步伐有三种,未来姗姗来迟,现在象箭一样飞逝,过去永远静止不动’。其实,...
    尘世走笔阅读 268评论 0 1