zoukankan      html  css  js  c++  java
  • absolute和relative元素 设置百分比宽高的差异

      一般元素在页面所占的空间包括:magin border padding content。以前一直以为子元素设置百分比宽高都是以父元素的content值为基准计算的。但是当子元素的position不同时,却是不同的结果。

    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)

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

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

    结论

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

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

  • 相关阅读:
    [BUUCTF]PWN14——not_the_same_3dsctf_2016
    flask cookie
    关于cookie和session
    mysql修改表操作
    MySQL 增删改查
    mysql数据类型
    python读写mysql
    聚合查询
    条件查询
    排序
  • 原文地址:https://www.cnblogs.com/shapeY/p/8001083.html
Copyright © 2011-2022 走看看