这篇文章主要介绍CSS实现九宫格的方法有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
创新互联公司主要从事成都网站制作、成都网站设计、网页设计、企业做网站、公司建网站等业务。立足成都服务武侯,十载网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:028-86922220
实现效果
效果如下,就是一个九宫格,点击九宫格中的任意一个小方块,其边框变成红色。
实现方法
我自己一共总结了4种方法来实现这个效果,前三种方法是大同小异,只有第四种表格布局比较特殊。下面我直接给出每一种布局方式相关的样式和DOM结构的源码。
1. float布局
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
float布局实现这个9宫格没什么好讲的,关键点在于对li子项设置margin-left:-4px;margin-top:-4px;这样就可以使相邻子块间的边框发生重叠,你可以不设置这个负的margin来看看效果,你会体会更深。整个CSS中我认为最精髓的地方在于hover的样式,给li子项设置了position:relative;。这个地方的精髓在于,对元素设置了relative后,其将脱离文档流,同时其层叠等级会比普通文档流高,就会使其内容覆盖在普通文档流之上,那么它被覆盖的border就会显示出来,同时遮挡住相邻元素的border。这个设置真的很精髓,后面两种方法和该方法差不多,我就不做过多讲解了。
2. flex布局
- 1
- 2
- 3
- 4
- flex
- 6
- 7
- 8
- 9
使用flex布局时,有一点需要注意,那就是不要给父容器ul.flex设置高度,如果你设置了高度,那么在垂直方向上子项的margin负值设置将会失效,具体原因我也不知道。如果你设置了高度后,还希望垂直方向的margin值生效,那么你就给ul.flex添加一个algin-content:flex-start;属性即可。这个具体为啥会这样,我也不是很明白,希望有理解的兄弟在评论区指导一下。该flex布局中,也可以在hover时添加z-index:2;来提高叠加等级。
3. grid布局
- 1
- 2
- 3
- 4
- grid
- 6
- 7
- 8
- 9
这里有一个地方需要注意,就是不要再给li子项设置宽度和高度。该grid布局中,也可以在hover时添加z-index:2;来提高叠加等级。
4. table布局
1 | 2 | 3 |
1 | table | 3 |
1 | 2 | 3 |
使用table布局时,有以下几点需要注意:
1、line-height的设置值需要与height的值保持一致。因为对于表格中的一行来说,它的高度取决于该行最大的单元格的高度或者行高,line-height与height不一致会导致该列中的边框溢出单元格。
2、要想使某个单元格的边框覆盖其他单元格的边框,必须给单元格设置position:absolute;而不是relative。
3、margin-left的设置值是border-width的1.5倍,这个是我在chrome下的测试结果,具体原因我也不清楚,希望有老铁评论区解答一下。
以上是CSS实现九宫格的方法有哪些的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!
当前标题:CSS实现九宫格的方法有哪些
网页地址:http://lswzjz.com/article/jocspd.html