div 布局_如何实现页面中有间隔的方格布局?

0ef3223924aed206931338c14ec96c47.png

来源 | https://juejin.cn/post/6897794764444762120

典型的布局示例

f9f1eb09bd6ee1529f0536fcb3fc1fb8.png

如上图所示的布局,方格中间有一定的间隙,间隙是固定的。应该如何布局会更加完美呢,比如要保证在布局完成的情况下,可以快速的添加一个元素依然保持这样的布局。 以及当出现第二行的时候,这样的布局依然能够不受影响。又不用修改太多的内容。

设置宽为100%和块元素的默认宽度

现在在这里说一个问题,就是块元素的宽度默认是占满一行,我们很容易和给元素设置100%混淆。其实呢,这两个虽然表现上很容易让我们以为他们展现的效果是一样的,因为这两种方式都是占满了父元素。但是他们之间还是有很大的区别的。 他们的区别主要在于元素的宽度是随着什么而变化的,如果设置100%的话,那么该元素的width始终是和父元素保持一致的,给该元素设置的margin是不会影响该元素width变化的。当然仅有父元素的宽度会影响该元素的width变化。 如果不设置宽的话,块元素是独占一行的,那么该元素的width,不仅受父元素的影响,也受该元素的margin的影响。

独占一行的块元素的宽设置margin的影响

记住以下两条规律
  1. 当给一个未设置宽的块级元素,设置了margin(水平方向)的话,那么margin值(正值)加上改元素的width的和等于父元素的宽度
  2. 当给一个未设置宽的块级元素,设置了margin(水平方向)的话,那么margin值(负值)刚好是该元素的宽度超出父元素的距离
如下图所示: 规律1示例:

32f27e655b4b2dfe2a0756c02e48b408.png

规律2示例:

7cd4ec290ef85c4ff527cabe53fd7f16.png

解决方案

划分平均区域

首先在一个横向区域,平分了5份,且横向排列,那么我们采用浮动的横向排列,且平均把每个元素设置成20%。

<ul class="list">  <li>li>  <li>li>  <li>li>  <li>li>  <li>li>ul>
.list{  overflow: hidden;}.list li{  width: 20%;    height: 100px;    float: left;}

在每个区域中放置内容,通过margin-right隔出间隔

<ul class="list">  <li>    <div class="content">div>  li>  <li>    <div class="content">div>  li>  <li>    <div class="content">div>  li>  <li>    <div class="content">div>  li>  <li>    <div class="content">div>  li>ul>
.list{  overflow: hidden;}.list li{  width: 20%;    height: 100px;    float: left;}.content{  margin-right: 10px;}

此时我们可以想象到,最后一个元素还多了一个10px的间距,那么最后一步就是如何解决这个间距的问题。

拉伸父元素,隐藏尾部的间隙

我们给list再套一个元素,让list在其父元素下拉伸,刚好隐藏掉多余的部分。

class="wrapper"> <ul class="list"> <li> <div class="content">div> li> <li> <div class="content">div> li> <li> <div class="content">div> li> <li> <div class="content">div> li> <li> <div class="content">div> li> ul></div>
.wrapper{  width: 800px;    overflow: hidden;}.list{  overflow: hidden;    margin-right: -10px;}.list li{  width: 20%;    height: 100px;    float: left;}.content{  margin-right: 10px;}

可以查看实际效果,最终能实现我们开头所展示的效果!且这种布局方式有很多的扩展性,如果一行是4个,那么只需要把每个元素的宽设置为 25%,且在元素的个数中减去一个就行。

本文完~

7e9801e6f0ce5271a3354e2ae3e522f4.png

9cc3e6e85db15c10067e5f1a2ff01b81.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值