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

组合使用 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(根本不用设置宽度)
    最外层宽度 = 中间层宽度 - 一个边框宽度
本文章著作权归饥人谷_蛮力拳猫和饥人谷所有,转载须说明来源!
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,875评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,569评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,475评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,459评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,537评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,563评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,580评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,326评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,773评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,086评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,252评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,921评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,566评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,190评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,435评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,129评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,125评论 2 352

推荐阅读更多精彩内容