CSS之内边距 外边距

css之内边距与外边距

外边距:

margin 
左边距 margin-left:数值 | auto
auto:即距离这个边最远的距离
右边距: margin-right:数值 | auto
上边距: margin-top:数值  这里不能用auto
下边距: margin-bottom:数值 这里也不能用auto

外边距 复合写法
1:margin: 0px(上) 0px(右) 0px(下) 0px(左)
2:margin: 0px(上) 0px(左右) 0px(下)
3:margin: 0px(上下边距) 0px(左右边距)
4:margin: 0px(上下左右边距都是0px)
代码示例:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>外边距</title>
    <link rel="stylesheet" href="index.css"/>   
</head>
<body>
    <div class="div1">我是div1</div>
    <div class="div2">我是div2</div>
</body>
</html>

div{
    width: 200px;
    height: 200px;
    background: red;
}
.div1{
    margin-left: 100px;
    margin-top: 100px;
    margin-bottom: 0px;
}
.div2{
    background: blue;
    margin-right: auto;
    margin-left: auto;
    /* margin-left: 300px;
    margin-top: -200px; */
}

微博三列布局

模仿页面 简单实现三列
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charser="utf-8"/>
    <title>微博三列布局</title>
    <style>
        .content{
            width : 900px;
            height : 1200px;
            background-color:yellow;
        }
        .div1{
            width:200px;
            height:1200px;
            background-color:red;
        }
        .div2{
            width:500px;
            height:1200px;
            background-color:green;
            margin-left:220px;
            margin-top:-1200px;
        }
        .div3{
            width:160px;
            height:1200px;
            background-color:blue;
            margin-left:auto;
            margin-top:-1200px;
        }
    </style>
</head>
<body>
    <div class="content">
        <div class="div1"></div>
        <div class="div2"></div>
        <div class="div3"></div>
    </div>
</body>
</html>

这里写图片描述

内边距

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>内边距</title>
    <link rel="stylesheet" href="index.css"/>
</head>
<body>
    <!-- 内边距 padding -->
    <!-- 左内距 padding-left:数值 -->
    <!-- 右内距 padding-right:数值 -->
    <!-- 上内距 padding-top -->
    <!-- 下内距 padding-bottom -->

    <!-- 内边距 复合写法 -->
    <!-- 1:padding: 0px(上) 0px(右) 0px(下) 0px(左) -->
    <!-- 2:padding: 0px(上) 0px(左右) 0px(下) -->
    <!-- 3:padding: 0px(上下边距) 0px(左右边距) -->
    <!-- 4:padding: 0px (上下左右边距都是0px)-->
    <div>xxxx</div>
</body>
</html>

背景色样式:

背景样式:background
背景颜色 background-color:颜色值
背景图片 background-image:url("图片路径")
背景图片平铺 backgroud-repeat:repeat-x(沿着x轴平铺) | repeat-y(沿着Y轴平铺) | no-repeat(不平铺)
背景图片定位 background-position: x y
x轴: 支持left center right 支持百分比 可以是数值(0px)
y轴: 支持top center bottom 支持百分比 可以是数值(0px)
如果是数值的话,代表离左边的距离,离上边的距离
如果是百分比的话,图片从左边移动到右边(不平铺且图片占容器的一小部分),百分比从0% -> 100%
图片从上边移动到下边,百分比从0% -> -100%,-200%

背景图片尺寸 background-size: x y(100px 100px) | cover | contain
background:复合写法
background:background-color background-image background-position background-repeat
定义多张图片的复合写法
background:url("timg.jpg") 0px 0px(图片位置)/100px 100px(图片大小) no-repeat,
       url("timg.jpg") 120px 120px(图片位置)/150px 150px(图片大小) no-repeat,
       url("timg.jpg") 60% -60%/200px 200px no-repeat,
       gold(背景颜色) url(timg.jpg) 90% -90%/250px 250px no-repeat;

这里写图片描述

外边距的坑:

父子结构下,父级与子级都设置了上边距的情况下,如果父级没有设置border的情况下,会引起塌陷问题,
即父级框会向下移动一段距离(这段距离是子级设置的上边距的长度)
比如没有border的代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8"/>
    <title>外边距的坑</title>
    <style>
        .div1{
            width:250px;
            height:250px;
            margin-top:5px;
            background-color:blue;
        }
        .div2{
            width:150px;
            height:150px;
            margin-top:50px;
            background-color:red;
        }
    </style>
</head>
<body>
    <div class="div1">
        <div class="div2">
            <div class="div3">q</div>
        </div>
    </div>
</body>
</html>
此时结果截图:

这里写图片描述

当设置了border时,这个塌陷问题将得到完美解决,这个塌陷问题是系统的原因,我们只负责解决
解决后的代码:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8"/>
    <title>外边距的坑</title>
    <style>
        .div1{
            width:250px;
            height:250px;
            margin-top:5px;
            background-color:blue;
            border:1px gold dashed;
        }
        .div2{
            width:150px;
            height:150px;
            margin-top:50px;
            background-color:red;
        }
    </style>
</head>
<body>
        <div class="div1">
            <div class="div2">
                <div class="div3">q</div>
            </div>
        </div>
</body>
</html>
此时运行结果截图:

这里写图片描述

从截图中可以看到,父级的位置恢复为原来的位置(原来位置:即没有创建div2的时候,div1所在的位置),塌陷问题得到解决.
设置内边距问题
一个div即可以设置外边距也可以设置内边距,当设置内边距时,该框体会在该方向上扩大相应的距离
比如初始情况为:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8"/>
    <title>外边距的坑</title>
    <style>
        .div1{
            width:200px;
            height:200px;
            margin-top:5px;
            background-color:blue;
            border:1px gold dashed;
        }
        .div2{
            width:100px;
            height:100px;
            margin-top:20px;
            background-color:red;
        }
    </style>
</head>
<body>
        <div class="div1">
            <div class="div2">
                <div class="div3">q</div>
            </div>
        </div>
</body>
</html>
结果截图:这个结果是宽200 高200时的结果,此时没有设置内边距

这里写图片描述

设置内边距时的代码:此时将边框顶边的内边距设置为50
代码示例:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8"/>
    <title>外边距的坑</title>
    <style>
        .div1{
            width:200px;
            height:200px;
            margin-top:5px;
            padding-top:50px;
            background-color:blue;
            border:1px gold dashed;
        }
        .div2{
            width:100px;
            height:100px;
            margin-top:20px;
            background-color:red;
        }
    </style>
</head>
<body>
        <div class="div1">
            <div class="div2">
                <div class="div3">q</div>
            </div>
        </div>
</body>
</html>
结果截图:此时外边框的高变为了250,外边框顶边距内边框顶边的距离为20+50=70像素

这里写图片描述

此时要想设置内边距同时又不想改变框体的大小,需要提前从外边框的高度中减去要设置的内边距的长度,即200-50=150,即外边框的属性设置为宽200像素,高150像素
代码示例
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8"/>
    <title>外边距的坑</title>
    <style>
        .div1{
            width:200px;
            height:150px;
            margin-top:5px;
            padding-top:50px;
            background-color:blue;
            border:1px gold dashed;
        }
        .div2{
            width:100px;
            height:100px;
            margin-top:20px;
            background-color:red;
        }
    </style>
</head>
<body>
        <div class="div1">
            <div class="div2">
                <div class="div3">q</div>
            </div>
        </div>
</body>
</html>

结果截图:此时的结果恢复为外边框为正放形
这里写图片描述

此时如果将子级的上边框也设置内边距,则也需要提前将子级的高减去相应的距离
代码示例:代码中高已经减去相应的内边距;
如果子级边框不设置边框顶边的内边距,设置边框底边的内边距,此时为了确保边框不因为内边距为改变,任然需要减去相应的内边距
代码为设置边框定边的内边距
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8"/>
    <title>外边距的坑</title>
    <style>
        .div1{
            width:200px;
            height:150px;
            margin-top:5px;
            padding-top:50px;
            background-color:blue;
            border:1px gold dashed;
        }
        .div2{
            width:100px;
            height:80px;
            margin-top:20px;
            padding-top:20px;
            background-color:red;
        }
    </style>
</head>
<body>
        <div class="div1">
            <div class="div2">
                <div class="div3">q</div>
            </div>
        </div>
</body>
</html>
结果截图:此时的结果不太明显

这里写图片描述

外边距的另一个坑:

同级结构下(注意不是父子结构,上面那个坑是父子级结构),外边距冲突的情况下(即两个同级的div,一个在上面,一个在下面,
你设置了外边距即magin-bottom,我也设置了外边距即(magin-top),此时两个外边距在一起会起冲突,
他们两个的距离会是两个边距中的较大者,而不是两个边距的值相加
代码示例:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8"/>
    <title>外边距的坑</title>
    <style>
        .div1{
            width:100px;
            height:100px;
            margin-bottom:20px;
            background-color:blue;
        }
        .div2{
            width:100px;
            height:100px;
            margin-top:30px;
            background-color:red;
        }
    </style>
</head>
<body>
    <div class="div1"></div>
    <div class="div2"></div>
</body>
</html>
结果截图:

这里写图片描述

盒模型的构成需要:<!-- 盒模型:构成:容器尺寸+padding+border+margin -->

六环练习

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>六环</title>
    <style>
        .div1{
            border: 1px dashed black;
            width: 600px;
            height: 554px;
            margin: 0 auto;
            padding-top: 46px;
        }
        .div2{
            border: 4px lightblue solid;
            background: gray;
            width: 500px;
            height: 475px;
            margin: 0 auto;
            padding-top: 25px;
        }
        .div3{
            background: pink;
            width:450px;
            height: 425px;
            margin: 0 auto;
            padding-top: 25px;
        }
        .div4{
            border: 1px dotted white;
            width: 400px;
            height: 380px;
            margin: 0 auto;
            padding-top: 20px;
        }
        .div5{
            border: 1px dashed white;
            width: 340px;
            height: 320px;
            margin: 0 auto;
            padding: 20px;
        }
        .div6{
            width:300px;
            height:300px;
            margin:auto;
            background-color: red;
        }
    </style>
</head>
<body>
    <div class="div1">
        <div class="div2">
            <div class="div3">
                <div class="div4">
                    <div class="div5">
                        <div class="div6"></div>
                    </div>
                </div>
            </div>
        </div>
    </div>
</body>
</html>

这里写图片描述

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值