百分比div宽高相等,制作简单实用宽高相等照片栏

先看代码:

<div class="box">
    <div class="item"></div>
    <div class="item"></div>
    <div class="item"></div>
    <div class="item"></div>
</div>
.box{font-size: 0;}
.item{
    display: inline-block;
    position: relative;
    width: 25%;
    height: 0;
    padding-bottom: 25%;
    background: red;
    }
.item:nth-child(2n){background: #ccc}
效果图

这里有两处解释一下:
1.item 设置 dispaly:inline-block 让他能在一行排列且不脱离文档流,再设置宽度为25%。此时原则上四个排列在一行的 div 。但由于inline-block自带属性让每个div之间有间隙 ,解决方法:在父元素box上添加font-size:0的属性
2.item 设置 height:0;padding-top/bottom:25% ,此时的padding是根据窗口的宽度来计算的。

最后我们再给item下面加上图片,item设置相对定位;img设置绝对定位、宽高为100%

全部代码:

<style>
    *{padding: 0;margin: 0;}
    .box{font-size: 0;}
    .item{
        display: inline-block;
        width: 25%;
        height: 0;
        padding-bottom: 25%;
        background: red;
        position: relative;
    }
    .item:nth-child(2n){background: #ccc}
    .item>img{
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }
</style>
<body>
    <div class="box">
        <div class="item">
            ![](images/headPic.jpg)
        </div>
        <div class="item">
            ![](images/headPic.jpg)
        </div>
        <div class="item">
            ![](images/headPic.jpg)
        </div>
        <div class="item">
            ![](images/headPic.jpg)
        </div>
    </div>
</body>
</html>
效果图
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,815评论 1 92
  • •前端面试题汇总 一、HTML和CSS 21 你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么? ...
    Simon_s阅读 2,228评论 0 8
  • 转载请声明 原文链接地址 关注公众号获取更多资讯 第一部分 HTML 第一章 职业规划和前景 职业方向规划定位...
    前端进阶之旅阅读 16,627评论 32 459
  • 使用纯 CSS 实现 500px 照片列表布局 文章很长,因为介绍了如何一步一步进化到最后接近完美的效果的,不想读...
    HZ充电大喵阅读 2,686评论 0 4
  • 人最基本的欲望,是衣食住行。满足了生存欲望,慢慢的会转移到精神欲望。 我结婚前,一直漂泊无定,想...
    风嘻嘻阅读 226评论 0 0