css的盒子模型--布局

时间:2020-12-09 12:35:07   收藏:0   阅读:17

盒子模型

1.盒子被分为两类,可以通过box-sizing控制

技术图片

.box1{
       width:500px;
       height: 500px;
       margin: 100px auto;
       border:2px solid #000000;
       padding:10px;
       /* width,height包括border和padding */
       box-sizing: content-box;
}

技术图片

2.width,height,padding,margin,border 百分比

2.1一般情况下

例如父盒子div宽 100px,子盒子div宽 50%,即50px;

2.2 html和body的height:100%

html的height:100%获取得到浏览器的高度,而body的height:100%依赖html的高度,以此类推,body里面的子元素的height根据body的height,(除了上面定位的情况)

可以想象成一条高度依赖链,元素的高度百分比需要定值高度的父元素。

所以如果这条依赖链有一个a元素没有设置height或者height为auto(height:auto,是指根据块内内容自动调节高度。),而a的子元素b{height:50%},因为b找不到一个被定义高度的父元素,所以认为b的height为0

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=<div></div>, initial-scale=1.0">
  <title>Document</title>
  <style type="text/css">
    *{
    margin:0px;
    padding:0px;
    }
    
    html,body{
    height:100%;
    }
    
    .box1{
        background:#ddd;
        /* height:50%; */
    }
    .box2{
        background:rgb(104, 53, 53);
        height:50%;
    }
    </style>
</head>
<body>
  <div class="box1">
    <div class="box2">
    </div>
  </div>
</body>
</html>

为什么宽度没有这样的特性,因为当元素(块级元素的特性)的width为auto,会占据所有的空间。而当元素(块内级元素的特性)的width为auto,width是由内部的子元素堆砌的时候,被设置为百分比的子元素会根据这个被堆砌的父元素。不像height一定需要父元素定值

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    html,body{
      height: 100%;
    }
   .box1{
       /*默认值*/
      width:auto;
      bac/kground-color: red;
      height: 100%;
      display: inline-block;
      box-sizing: border-box;
      padding:50px
   }
   .box2{
    width:50%;
    background-color: yellow;
    height: 100%;
   }
   .box3{
     height:50px;
     width:500px;
   }
  </style>
</head>
<body>
    <div class="box1">
      <div class="box3"></div>
      <div class="box2"></div>
    </div>
</body>
</html>

3.块级元素和内联元素

3.1块级元素: 可以设置宽高,padding,margin;总是独占一整行。

设置为块级元素:display:block,或者有些元素默认为块级元素,p,h,ul,li,ol,dl,dt,dd

3.2行内元素:总是在一行内;不可以设置宽高,宽高都是根据里面的内容自适应,padding,margin这两个属性只能设置左右两个方向。

设置为行内元素:display:inline-block;或者有些元素默认为行内元素,比如a ,i , em,span

3.3 absolute或者fixed后,元素的性质同display:inline-block,即宽高可以由内部撑开,也可以设置。

评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!