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

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

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

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

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

  1.  
    .box{
  2.  
    width: 20%;//width: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.  
    width: 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.  
    width: 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.  
    width: 100%;
  21.  
    height: 100%;
  22.  
    background: yellow;
  23.  
    }

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

最新文章

  1. 夺命雷公狗-----React---19--表单的值的修改
  2. MicroERP软件更新记录1.0
  3. 56992 vuser_init.c(12): Error: Socket descriptor not found.
  4. [工具类]DataTable与泛型集合List互转
  5. Sql Server 里的向上取整、向下取整、四舍五入取整
  6. Js 和 PHP 中保留小数点后X位数的方法 toFixed、round、number_format、sprintf
  7. 在这个年纪,打DOTA冲分有那么可笑么?
  8. 深入理解memcached
  9. POJ 1830.开关问题(高斯消元)
  10. css 弹出框
  11. Hibernate Transformers之三种结果转换说明
  12. 【Excel】SUMIF 或用 筛选器 实现挑选含有某些字段的值,然后把这些值所对应的后面某列上的值相加
  13. 20181114 Redis
  14. 使用digitalocean进行项目开发
  15. XML之命名空间的作用(xmlns)
  16. java 基础-思维导图
  17. 【Linux】文件批量重命名
  18. 2018.09.17 bzoj1260: [CQOI2007]涂色paint(区间dp)
  19. rdlc报表随笔心得 ,基本结构和一些表达式。
  20. WPF透明窗体不支持缩放解决方案

热门文章

  1. HDU 1017 直接暴力。
  2. vue-cli搭建vue项目(单页面应用)
  3. hexo博客
  4. Windows、Linux之间传输文件的几种方式
  5. GPU体系架构(二):GPU存储体系
  6. RestTemplate + okhttp 实现远程调用
  7. python基礎學習第一天
  8. vue(七)--监听属性(watch)
  9. 纪中10日T3 2296. 神殿 bfs
  10. BSP与HAL关系(转)