zoukankan      html  css  js  c++  java
  • CSS 实现一个自适应的正方形

     

    传统方法正方形用固定的形式写 直接长=宽写固定的值如下

    1.  
      .box{
    2.  
      200px;
    3.  
      height: 200px;
    4.  
      background: pink;
    5.  
      color: #666;
    6.  
      }

    但是很多情况下,在移动端的设计里,图片的宽度随着不同的移动设备进行改变的,这个时候就需要用到自适应的正方形的实现。

    下面介绍两种比较简单的实现方法:

    方法一:CSS3 vw 单位,vw是相对于视口的宽度。视口被均分为100单位的vw。1vw = 1% viewport width

    1.  
      .box{
    2.  
      20%;//20vw也可以
    3.  
      height: 20vw;
    4.  
      background: pink;
    5.  
      }

    方法二:设置盒子的padding-bottom样式,让盒子的padding-bottom和盒子的宽度一样,同时设置heigh = 0px;

    1.  
      <!DOCTYPE html>
    2.  
      <html>
    3.  
      <head>
    4.  
      <meta charset="utf-8">
    5.  
      <meta http-equiv="X-UA-Compatible" content="IE=edge">
    6.  
      <title></title>
    7.  
      <link rel="stylesheet" href="">
    8.  
      </head>
    9.  
      <style>
    10.  
      *{
    11.  
      margin: 0;
    12.  
      padding: 0;
    13.  
      }
    14.  
      .box{
    15.  
      20%;
    16.  
      /* 设置height为0 ,避免盒子被内容撑开多余的高度 */
    17.  
      height: 0px;
    18.  
      /* 把盒子的高撑开,
    19.  
      和width设置同样的固定的宽度或者百分比 ,
    20.  
      百分比相对的是父元素盒子的宽度 */
    21.  
      padding-bottom: 20%;
    22.  
      background: pink;
    23.  
      color: #666;
    24.  
      }
    25.  
      </style>
    26.  
      <body>
    27.  
      <div class="box">
    28.  
      <p>&nbsp;这是一个自适应的正方形</p>
    29.  
      </div>
    30.  
      </body>
    31.  
      </html>

    要注意的是,如果这里没有写height:0px;当盒子里面有内容的时候,盒子会被内容撑大

          

    如果把padding-bottom改成padding-top会出现什么现象?

           

    可以看出来在正方形中有内容的时候,内容会现实在正方形外面,这是因为默认文字是从左到右,从上到下的排列,所以paddin-top以后文字会在正方形外面,所以这里的paddin-bottom和padding-top并不能混用

    另外因为盒子设置了heigh:0px;导致该元素里面再有子元素的时候,就无法正常设置高度。所以我们需要用到position: absolute;使当前内容脱离文档流,那么内容的高度百分比参照的就是父级的宽度

    1.  
      *{
    2.  
      margin: 0;
    3.  
      padding: 0;
    4.  
      }
    5.  
      .box{
    6.  
      20%;
    7.  
      /* 设置height为0 ,避免盒子被内容撑开多余的高度 */
    8.  
      height: 0px;
    9.  
      /* 把盒子的高撑开,
    10.  
      和width设置同样的固定的宽度或者百分比 ,
    11.  
      百分比相对的是父元素盒子的宽度 */
    12.  
      padding-bottom: 20%;
    13.  
      background: pink;
    14.  
      color: #666;
    15.  
      position: relative;
    16.  
      overflow: hidden;
    17.  
      }
    18.  
      p{
    19.  
      position: absolute;
    20.  
      100%;
    21.  
      height: 100%;
    22.  
      background: yellow;
    23.  
      }

    这样子盒子里面的内容就把正方形占满啦

  • 相关阅读:
    比特币and区块链
    C#汽车租赁系统 完整版
    C#托盘程序设置
    网络电视精灵项目
    C#文件操作 File(静态类)
    深入解读XML解析
    ListView 控件总结
    DataGridView 的使用总结
    动态添加节点
    IrisSkin2.dll 添加皮肤
  • 原文地址:https://www.cnblogs.com/lsongyang/p/10783000.html
Copyright © 2011-2022 走看看