美文网首页
搞清水平等距排列——九宫格

搞清水平等距排列——九宫格

作者: NathanYangcn | 来源:发表于2016-12-27 19:49 被阅读0次

组合使用 float 和 负margin 就能完成水平等距排列效果,但在我手里貌似不那么听话,总是跑偏不到中间位置,说明我还不那么懂它,那就分析一下问题所在。

水平等距排列效果制作过程

步骤1:创建并初始化测试代码

  • 为了便于观察,给每一个元素添加border或background-color,以此区分嵌套层级
    得到如下代码:
-----------html部分-----------------
<body>
  <ul>
    <li>1</li> <li>2</li> <li>3</li> <li>4</li> <li>5</li> <li>6</li> <li>7</li> <li>8</li> <li>9</li>
  </ul>
</body>
-----------CSS部分-----------------
  <style>
 * {margin: 0; padding: 0;}
ul,li {list-style: none;}
ul {border: 2px blue solid; width: 320px; padding: 10px;}
li {background-color: red; width: 100px; height: 100px;}
  </style>
有9个那么长,大概900px

步骤2:初步实现样式、寻找问题

  • 标签 li :添加 float 、margin
  • 标签 ul :添加 负margin
    增加的代码如下:
-----------CSS部分-----------------
  <style>
    ul {margin-left: -10px; overflow: hidden;}
    li {float: left; margin-left: 10px;}
  </style>
这个结果不是我想要的
  • 很显然没有得到想要的结果,仔细对比一下发现存在两个问题:
  1. 步骤2中的 "标签ul" - margin: -10px; 覆盖了步骤1中 "标签ul" - margin: 0 auto; 造成 "标签li" 无法居中,却被 "标签ul" 拉偏了位置
  2. "标签ul" 本身宽度不足以放下 "带有左边框的3个标签li",所以也没有按九宫格顺序排列

3.解决问题

  1. 首先,CSS代码由上至下按序排列,造成下方代码会覆盖上方代码,所以margin无法调序,但可以使用 "标签div" 包裹 "标签ul" ,再去实现居中就容易得多
  2. 其次,需要改变 "标签ul" 的最小宽度,使其内部可以在以行内放下 "带有左边框的3个标签li"
    代码修改部分
-----------html部分-----------------
<div class="box">
  <ul> 
    <li>1</li> <li>2</li> <li>3</li> <li>4</li> <li>5</li> <li>6</li> <li>7</li> <li>8</li> <li>9</li>
  </ul>
</div>
-----------CSS部分-----------------
<style>
  .box {width: 320px; margin: 0 auto;} /*增加width、margin*/
  ul {width: 330px; /*width: 320px;*/ /*margin: 0 auto;*/} /*修改width,删除margin*/
</style>
显然问题解决了,但不够美

4.美化:使其更像九宫格

美化一下,使其看起来更像九宫格,增加代码如下

-----------CSS部分-----------------
  <style>
    li {margin: 5px 0 5px 10px;}
  </style>
九宫格出来了

5.几句解释

现在 "标签li" 在 "标签div" 中基本上算是居中了,但左右还是存在缝隙,这是因为所有元素都设有边框,而边框是要占位置的,"标签div" 在屏幕正中央,但 "标签ul" 会将 "标签li" 向右拖移2px,此时去掉 "标签ul" 的边框才是想要的最终节果, "标签li" 水平等距排列并且居中了

- 最后的总结

  • 1.水平等距排列,是需要三层的
    最内层负责浮动
    中间层负责偏移
    最外层作为参照物制造错觉,让最内层看起来是水平等距排列;最后利用合适的方法,将这个整体固定在页面上
  • 2.它们的宽度问题
    最内层子元素宽度根据实际需求设定宽度
    中间层宽度最小宽度 = 带边框的最内层子元素宽度 * N(根本不用设置宽度)
    最外层宽度 = 中间层宽度 - 一个边框宽度
本文章著作权归饥人谷_蛮力拳猫和饥人谷所有,转载须说明来源!

相关文章

  • 搞清水平等距排列——九宫格

    组合使用 float 和 负margin 就能完成水平等距排列效果,但在我手里貌似不那么听话,总是跑偏不到中间位置...

  • Autolayout布局九宫格

    Autolayout纯代码布局九宫格 单行固定间隔排列: 水平布局设置 垂直布局设置 固定宽度设置: 水平布局 垂...

  • 几种常见的布局方式(二)

    三列布局 两侧两列固定宽度,中间列自适应宽度 如何实现 实例代码如下 效果图如下 水平等距排列 思路:li的大...

  • iOS 开发循环创建布局

    九宫格 横向排列

  • 图解+动画 | 详解 Masonry 等距排列

    Masonry 是对原生AutoLayout系统的第三方封装,为原生AutoLayout提供了链式编程的API,方...

  • iOS - 九宫格的基本实现

    在开发中,经常会遇到要将按钮或者图片的有序排列的需求,在这当中属九宫格排列的需求最为常见,当然很多人会说九宫格的布...

  • div如何水平、垂直排列

    主要通过float属性实现: 水平排列 垂直排列

  • 表单 - Forms

    垂直排列表单 一般输入控件都用 .form-group元素包裹起来 水平排列表单 水平排列表单要给表单添加 .fo...

  • 九宫格总结

    九宫格总结 我将尽可能的去解释清楚九宫格的规律 计算九宫格的排列,需要把以下几个条件准备好列数宽度高度添加的序号c...

  • 第五节 FlutterROW 水平布局

    Flutter中的row控件就是水平控件,它可以让Row里边的子元素进行水平排列。 Row控件可以分为灵活排列和非...

网友评论

      本文标题:搞清水平等距排列——九宫格

      本文链接:https://www.haomeiwen.com/subject/twmjvttx.html