zoukankan      html  css  js  c++  java
  • CSS盒模型属性详细介绍

     一、概述

      CSS盒模型是定义元素周围的间隔、尺寸、外边距、边框以及文本内容和边框之间内边距的一组属性的集合。

      示例代码:

      

     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title>Document</title>
     6     <style type="text/css">
     7         *{margin: 0;padding: 0;}
     8         
     9         .boxWrapper{
    10             width: 150px;
    11             height: 150px;
    12             background: #ccc;
    13             margin: 20px 20px 20px 20px;
    14             padding: 20px 20px 20px 20px;
    15             border: 20px solid #00f;
    16         }
    17         .boxInner{
    18             width: 100px;
    19             height: 100px;
    20             border: 10px solid #000;
    21         }
    22     </style>
    23 </head>
    24 <body>
    25     <div class="boxWrapper">
    26         <div class="boxInner"></div>
    27     </div>
    28 </body>
    29 </html>
      效果图:

      

       由此可见:外边距margin是不可见的,如果设置了父元素的背景,就可以看到;背景色在边框区域设置一个不同的背景,就可以看到内边距(padding)区域。并且盒模型是由margin(外边界)+border(边框)+padding(内边距)+content(内容)构成的。

      下面,我们来介绍CSS盒模型的这些属性:

    二、属性介绍

    1.   margin属性

        概念:margin属性应用于盒子外面的空间,或者是位于盒子与文档中其他元素之间的区域,或者是盒子与浏览器窗口之间的区域。margin长在盒子外围的,不会对盒子本身的大小造成影响。

        属性:margin-top(上外边界)、margin-right(右外边界)、margin-bottom(下外边界)、margin-left(左外边界)

        值:支持length、百分比、auto

        用法:

        margin设置方法:
        1: margin:10px 四周(上,右,下,左)
        2: margin:10px 20px 上下 左右
        3: margin:10px 20px 30px 上 左右 下
        4:margin:10px 20px 30px 40px 上右下左
        5:margin支持负值!!
        6:让子元素在父元素里面左右居中:margin:0 auto;

        7:margin常见的bug:

    •       a:当父元素和子元素都没有浮动的情况下:给第一个子元素添加margin-top:会错误的把margin值加在父元素上面
          实例代码:

            

     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title>Document</title>
     6     <style type="text/css">
     7         *{margin: 0;padding: 0;}
     8         
     9         .boxWrapper{
    10             width: 150px;
    11             height: 150px;
    12             background: #ccc;
    13         }
    14         .boxInner{
    15             width: 100px;
    16             height: 100px;
    17             margin-top: 20px;
    18             background: skyblue;
    19         }
    20         .other{
    21             width: 50px;
    22             height: 50px;
    23             background: #999;
    24             /* margin-top: 20px; */
    25         }
    26     </style>
    27 </head>
    28 <body>
    29     <div class="boxWrapper">
    30         <div class="boxInner"></div>
    31         <div class="other"></div>
    32     </div>
    33 </body>
    34 </html>
          效果如图:

          

        结论:当父元素里的第一个子元素(块元素),添加margin-top的时候,会错误的把margin-top的值添加给父元素(建立在当前的元素们,没有添加边框和浮动的前提下)

        解决方法: 

    1.     bfc 给父元素添加overflow:hidden;推荐使用
    2.     给父元素和子元素添加浮动属性;
    3.     可以给父元素添加边框
    4.     把margin改为padding
    •       b:相邻两个元素上下margin会重叠,按照较大的值设置。
            示例代码:

            

     1         .boxInner{
     2              100px;
     3             height: 100px;
     4             margin-bottom: 20px;
     5             background: skyblue;
     6         }
     7         .other{
     8              50px;
     9             height: 50px;
    10             background: #999;
    11             margin-top: 20px;
    12         }
    13     </style>
    14 </head>
    15 <body>
    16     <div class="boxWrapper">
    17         <div class="boxInner"></div>
    18         <div class="other"></div>
    19     </div>
    20 </body>
    21 </html>
        效果图:

        

         可以看出外边距折叠。当boxInner的下外边距和other元素的上外边距接触时,外边距发生了折叠!,他们之间只有20px,而不是40px;

        2.边框

          1.border属性:用来控制盒边框的宽度,样式,颜色。

          属性(不支持百分比)常用px

          border:10px solid red;

          border-10px;
          border-style:solid;
          border-color:red;


            1:线性: solid(实线) dashed(虚线) dotted(点状线) double(双线) none/0(没有边框)

            2:给单一一个方向添加边框:
            border-left/right/top/bottom:10px solid yellow;


            3:边框设置方法;
            border:solid red;
            border-;
            一个值:四周
            两个值:上下 左右
            三个值:上 左右 下
            四个值:上右下左

            4:transparent; 代替颜色值 为 透明

        3.padding属性:内边距是元素的内容和边框之间的区域

          用法:

          1:padding是添加在父元素(盒子)上的
          2:padding 调整子元素在父元素里面的位置关系
          3:padding会把盒子撑大。
          4:想让盒子保持原有的大小:在宽高的基础上减掉padding值。
          5:给单一一个方向添加padding值: padding-top/bottom/left/right:
          6:
          padding设置方法:
          padding:10px 四周
          padding:10px 20px 上下 左右
          padding:10px 20px 30px 上 左右 下
          padding:10px 20px 30px 40px 上右下左

          7:padding不会对背景图造成影响
          8:padding的值不能为负值!!!

       4.对比padding和margin

         1.padding区域是边框内边缘和内容外边缘之间的区域。

         2.auto关键字对padding属性不起作用。

         3.padding属性不可以接受复制。

         4.padding不存在内边距折叠,只有外边距折叠。

  • 相关阅读:
    线程池:第一章:线程池的底层原理
    实战:第一章:防止其他人通过用户的url访问用户私人数据
    java程序报错:Unable to open debugger port (127.0.0.1:63959): java.net.SocketException "socket closed",编译过来就是无法打开调试器端口,套接字已关闭
    面试:第十三章:中高级程序员面试
    队列:第一章:阻塞队列
    我的分享:第三章:SpringCould五大组件
    Linux系统:第十章:服务器环境搭建
    深入理解JUC:第六章:Semaphore信号灯
    编写高质量JS代码的68个有效方法(十三)
    前端构建之gulp与常用插件
  • 原文地址:https://www.cnblogs.com/my12-28/p/12358988.html
Copyright © 2011-2022 走看看