不怕你用不上!CSS 列表项布局技巧

编者按:

为了避免引入 HTML 标签自身的样式,本文未考虑 HTML 语义化的提倡,以使得行文与示例代码更加简洁。这是文章写做须要,而非代码风格示范。css

在开发中咱们常常会遇到关于如何展现列表的问题,例如:html

  • 图片选择器列表

  • 人员部门选择列表

  • 工做状态列表

通用方法

为了让其看起来更加温馨美观,一般咱们会在每一个列表项上添加 margin-rightmargin-bottom 属性来隔开它们,而后一行超过容器长度后进行换行前端

那么在各类状况下,如何处理列表项中margin-rightmargin-bottom,让列表间隔和换行看起来更加天然美观是本篇的重点css3

各类状况下的布局

元素宽度已知,即知道每行最多多少个,且全部元素都在一个容器中

  1. 思路:item 在一个容器中,每第三个去掉 margin-right,最后三个取消 margin-bottom(如最后一行不满 3 个也不影响)
  2. 关键代码
<div class='container'>
  <div class='item'>宽度已知,最多放三个</div>
  <div class='item'>宽度已知,最多放三个</div>
  <div class='item'>宽度已知,最多放三个</div>
  ...
</div>

<style>
/* scss code */
.container {
  .item {
    margin-right: 30px;
    margin-bottom: 20px;

    &:nth-child(3n) { margin-right: 0; }
    &:nth-last-child(-n+3) { margin-bottom: 0; }
  }
}
</style>
  1. 运行截图

  1. 完整代码:元素宽度已知,全部元素都在一个容器

元素宽度已知 或 未知,且元素按照行数在相应容器中

  1. 思路:最后一个 container 去掉 margin-bottom,最后一个 item 去掉 magin-right
  2. 关键代码
<div class='container'>
  <div class='item'></div>
  <div class='item'></div>
</div>
<div class='container'>
  <div class='item'></div>
  <div class='item'></div>
  <div class='item'></div>
</div>
<div class='container'>
  <div class='item'></div>
</div>

<style>
/* scss code */
.container {
  margin-bottom: 20px;
  &:last-child { margin-bottom: 0; }

  .item {
    margin-right: 30px;
    &:last-child { margin-right: 0; }
  }
}
</style>
  1. 运行截图

  1. 完整代码:元素宽度已知或未知,且按照行数在相应容器

元素宽度未知,即不知道一行最多多少个,且全部元素都在一个容器中,常见于 flex 布局

法1:Flex 布局

  1. 思路:利用 flex 布局的 justify-content 主轴属性来控制元素的间距
  2. 缺点:flex 虽然强大,可是面对 长度不定的列表项布局 仍是不能很好知足要求
  3. 关键代码
<div class='container'>
  <div class='item'>两个能够成一行</div>
  <div class='item'>两个能够成一行</div>
  <div class='item'>这三个字</div>
  <div class='item'>独成一行呀独成一行呀独成一行呀独成</div>
  <div class='item'>两个才能成一行呀</div>
  <div class='item'>四个</div>
</div>

<style>
/* scss code */
.container {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; /* 能够尝试其余值,但效果仍很差 */

  .item {
    /* margin-right: 30px; 能够不用 m-r,由 flex 来控制左右间距 */
    margin-bottom: 20px;
  }
}
  1. 运行截图

  1. 完整代码:元素宽度已知或未知,且按照行数在相应容器

法2:负margin

  1. 接下来介绍 负margin 方法,能够很好的解决 长度不定的列表项布局 问题
  2. 思路:用一个 wrapper 包在最外层,container 设置 负的 margin 来抵消 item 的 外边距

参考连接:https://segmentfault.com/q/1010000005882081/a-1020000005894468git

  1. 关键代码
<div class="wrapper">
  <div class='container'>
    <div class='item'>两个才能成一行呀</div>
    <div class='item'>两个才能成一行呀</div>
    <div class='item'>这三个字</div>
    <div class='item'>独成一行呀独成一行呀独成一行呀独</div>
    <div class='item'>两个才能成一行呀</div>
    <div class='item'>四个</div>
  </div>
</div>

<style>
/* scss code */
.wrapper {
  padding: 10px;
  border: 2px solid rgb(240, 103, 103);

  .container {
    display: flex;
    flex-wrap: wrap;
    margin-right: -30px;
    margin-bottom: -20px;

    .item {
      margin-right: 30px;
      margin-bottom: 20px;
    }
  }
}
</style>
  1. 运行截图

  1. 完整代码:法2:元素宽度未知,且全部元素都在一个容器

总结

多多利用 css3 属性来帮助咱们更好的布局列表,避免使用 js 控制列表项,作到 css 与 js 解耦,更利于项目的维护github

以上可能未包含全部状况,欢迎提出或者分享其余更好的解决办法segmentfault


文 / Lawler61
Learn and to learn.
Github: https://github.com/lawler61
做者博客: www.freeze61.me

编 / 荧声微信

本文由创宇前端做者受权发布,版权属于做者,创宇前端出品。欢迎注明出处转载本文。文章连接:https://knownsec-fed.com/2018...app

想要订阅更多来自知道创宇开发一线的分享,请搜索关注咱们的微信公众号:创宇前端(KnownsecFED)。欢迎留言讨论,咱们会尽量回复。布局

欢迎点赞、收藏、留言评论、转发分享和打赏支持咱们。打赏将被彻底转交给文章做者。

感谢您的阅读。

相关文章
相关标签/搜索