absolute和relative元素 设置百分比宽高的差别

本文转载于:猿2048网站absolute和relative元素 设置百分比宽高的差别php

  通常元素在页面所占的空间包括:magin border padding content。之前一直觉得子元素设置百分比宽高都是以父元素的content值为基准计算的。可是当子元素的position不一样时,倒是不一样的结果。ide

demo

  用以下小demo测试:测试

<aside class="container">
    <div class="test">
    </div>
  </aside>
    .container{
      position: relative;
      margin: 100px auto;
      padding: 20px;
      height: 100px;
      width: 100px;
      border : 10px solid green;
      background-color: red;
    }

    .test{
      height: 20%;
      width: 20%;
      position: relative;
      top: 0;
      left: 0;
      background-color: #000000;
    }

  效果以下:网站

  

  子元素以父元素的content宽度100px为基准计算的20%为20px 且是以content为参考进行的偏移(虽然这里为0)spa

  若子元素position为absolute时,效果以下:code

  此时子元素的百分比宽度是以 父元素的 padding + content的值进行计算的 为28px; 并且也是以padding为基础进行偏移的。blog

结论

  absolute元素的百分比宽高 计算时按照的包含块的 padding + content的值算的,偏移的参考也要加上padding那部分get

  relative元素的百分比宽高 计算时按照的包含块的 content的值算的.it