实现九宫格布局,你能想到多少种方法?

简介: 最近看到一个面试题:实现一个九宫格布局,用尽可能多的方式去实现? 搜了一下牛客面经,腾讯、字节、百度、网易、京东等的面经中都出现过这道题目。所以今天就来实现一下,看有多少种实现方式(下面实现的九宫格布局是自适应页面大小的)

最近看到一个面试题:实现一个九宫格布局,用尽可能多的方式去实现? 搜了一下牛客面经,腾讯、字节、百度、网易、京东等的面经中都出现过这道题目。所以今天就来实现一下,看有多少种实现方式(下面实现的九宫格布局是自适应页面大小的)。

实现效果如下:


网络异常,图片无法展示
|


首先,定义好通用的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>
复制代码


公共样式:

ul {
  padding: 0;
}
li { 
  list-style: none;
  text-align: center;
  border-radius: 5px;
  background: skyblue;
}
复制代码


1. flex实现


对于九宫格布局,我首先想到的就是flex布局,flex布局实现九宫格很简单,需要设置一个flex-wrap: wrap;使得盒子在该换行的时候进行换行。

由于我们给每个元素设置了下边距和右边距,所以最后同一列(3、6、9)的右边距和最后一行(7、8、9)的下边距撑大了ul,所以这里使用类型选择器来消除他们的影响。最终的实现代码如下:


ul {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  height: 100%;
}
li {
  width: 30%;
  height: 30%;
  margin-right: 5%;
  margin-bottom: 5%;
}
li:nth-of-type(3n){ 
  margin-right: 0;
}
li:nth-of-type(n+7){ 
  margin-bottom: 0;
}
复制代码


2. grid实现


grid布局相对于flex布局来说,实现九宫格就更加容易了,只需要设置几个属性即可:

ul {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: 30% 30% 30%; 
  grid-template-rows: 30% 30% 30%; 
  grid-gap: 5%; 
}
复制代码


其中grid-template-columns属性用来设置每一行中单个元素的宽度,grid-template-rows属性用来设置每一列中单个元素的高度,grid-gap属性用来设置盒子之间的间距。

其实Grid布局还是很有用,很方便的,近期会有一篇详解grid布局的文章,有想了解的小伙伴可以关注一波嗷~


3. float实现


这里需要给每个盒子设置固定的宽高,为了让它自动换行,可以使用float来实现,由于子元素的浮动,形成了BFC,所以父元素ul使用overflow:hidden;来消除浮动带来的影响。最终的实现代码如下:


ul {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
li {
  float: left;
  width: 30%;
  height: 30%;
  margin-right: 5%;
  margin-bottom: 5%;
}
li:nth-of-type(3n){ 
  margin-right: 0;
}
li:nth-of-type(n+7){ 
  margin-bottom: 0;
}
复制代码


4. inline-block实现


其实inline-block的作用和上面float的作用是一样的,都是用来让元素换行的,实现代码如下:


ul {
  width: 100%;
  height: 100%;
  letter-spacing: -10px;
}
li {
  width: 30%;
  height: 30%;
  display: inline-block;
  margin-right: 5%;
  margin-bottom: 5%;
}
li:nth-of-type(3n){ 
  margin-right: 0;
}
li:nth-of-type(n+7){ 
  margin-bottom: 0;
}
复制代码


需要注意的是,设置为inline-block的元素之间可能会出现间隙,就可能出现下面这种情况:


网络异常,图片无法展示
|


这里使用了letter-spacing属性来消除这种影响,该属性可以用来增加或减少字符间的空白(字符间距)。使用之后就正常了,出现了预期的效果。也可以给ul设置font-size: 0;来消除盒子之间的字符间距:


ul {
  font-size: 0;
}
复制代码


5. table实现


HTML结构:

<ul class="table">
  <li>
    <div>1</div>
    <div>2</div>
    <div>3</div>
  </li>
  <li>
    <div>4</div>
    <div>5</div>
    <div>6</div>
  </li>
  <li>
    <div>7</div>
    <div>8</div>
    <div>9</div>
  </li>
</ul>
复制代码


table布局也不算太难,首先给父元素设置为table布局,然后使用border-spacing设置单元格之间的间距,最后将li设置为表格行,将div设置为表格单元格,CSS样式如下:

.table {
  width: 100%;
  height: 100%;
  display: table;
  border-spacing: 10px;
}
li {
  display: table-row; 
}
div {
  width: 30%;
  height: 30%;
  display: table-cell;
  text-align: center;
  border-radius: 5px;
  background: skyblue;
}
复制代码


6. 总结


对于上述实现方式,总结如下:

  • flex布局也是我平时用的比较多的布局方式,虽然其还有一些兼容性问题,但是由于我做的是B端项目,基本不需要考虑兼容问题。其实flex布局主要适用于移动端项目;
  • grid布局实现起来非常方便,但是它的规范并未成熟,主流的浏览器使用较少,不推荐使用在企业项目中;
  • 使用float可以使元素脱离文档流,形成BFC,在重新渲染时不会影响其他的元素。需要注意使用float的元素其父元素会塌陷,需要清除浮动。
  • 使用inline-block来实现九宫格布局时,定义了inline-block的元素之间会出现间隙,需要清除;
  • table布局现在感觉用的比较少了,几乎很少在项目中使用table布局。
相关文章
|
12天前
|
前端开发 JavaScript
瀑布流布局怎样实现
瀑布流布局怎样实现
|
4月前
只用一个背景图片实现九宫格抽奖(uniapp纯代码)
只用一个背景图片实现九宫格抽奖(uniapp纯代码)
41 0
|
8月前
【项目经验】elementui抽屉(从下到上方向)实现向上拉伸
elementui抽屉二次封装(可以向上拉伸)改变抽屉高度
|
12月前
|
小程序 搜索推荐 开发者
谈谈宝石方块游戏中的设计
宝石方块是在上一个俄罗斯方块工程的基础上改编的,所以制作起来很快,我只用了不到两天的时间就完成了游戏的功能,后续又花了几天的时间制作游戏的界面,优化游戏的体验。
108 0
|
前端开发
前端学习案例3-三栏布局1 原
前端学习案例3-三栏布局1 原
49 0
前端学习案例3-三栏布局1 原
|
前端开发
前端学习案例4-三栏布局2
前端学习案例4-三栏布局2
49 0
前端学习案例4-三栏布局2
|
前端开发
前端学习案例7-三栏布局5
前端学习案例7-三栏布局5
60 0
前端学习案例7-三栏布局5
|
前端开发
前端学习案例6-三栏布局4
前端学习案例6-三栏布局4
45 0
前端学习案例6-三栏布局4
|
前端开发
前端学习案例5-三栏布局3
前端学习案例5-三栏布局3
52 0
前端学习案例5-三栏布局3
|
前端开发
前端学习案例1-三栏布局
前端学习案例1-三栏布局
74 0
前端学习案例1-三栏布局