时间:2020-11-29来源:www.pcxitongcheng.com作者:电脑系统城
典型的布局示例
如上图所示的布局,方格中间有一定的间隙,间隙是固定的。应该如何布局会更加完美呢,比如要保证在布局完成的情况下,可以快速的添加一个元素依然保持这样的布局。以及当出现第二行的时候,这样的布局依然能够不受影响。又不用修改太多的内容。
设置宽为100%和块元素的默认宽度
现在在这里说一个问题,就是块元素的宽度默认是占满一行,我们很容易和给元素设置100%混淆。其实呢,这两个虽然表现上很容易让我们以为他们展现的效果是一样的,因为这两种方式都是占满了父元素。但是他们之间还是有很大的区别的。
他们的区别主要在于元素的宽度是随着什么而变化的,如果设置100%的话,那么该元素的width始终是和父元素保持一致的,给该元素设置的margin是不会影响该元素width变化的。当然仅有父元素的宽度会影响该元素的width变化。如果不设置宽的话,块元素是独占一行的,那么该元素的width,不仅受父元素的影响,也受该元素的margin的影响。
独占一行的块元素的宽设置margin的影响
记住以下两条规律
如下图所示:
规律1示例:
规律2示例:
解决方案
划分平均区域
首先在一个横向区域,平分了5份,且横向排列,那么我们采用浮动的横向排列,且平均把每个元素设置成20%。
1 2 3 4 5 6 7 |
< ul class = "list" > < li ></ li > < li ></ li > < li ></ li > < li ></ li > < li ></ li > </ ul > |
1 2 3 4 5 6 7 8 |
.list{ overflow : hidden ; } .list li{ width : 20% ; height : 100px ; float : left ; } |
在每个区域中放置内容,通过margin-right隔出间隔
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
< ul class = "list" > < li > < div class = "content" ></ div > </ li > < li > < div class = "content" ></ div > </ li > < li > < div class = "content" ></ div > </ li > < li > < div class = "content" ></ div > </ li > < li > < div class = "content" ></ div > </ li > </ ul > |
1 2 3 4 5 6 7 8 9 10 11 |
.list{ overflow : hidden ; } .list li{ width : 20% ; height : 100px ; float : left ; } .content{ margin-right : 10px ; } |
此时我们可以想象到,最后一个元素还多了一个10px的间距,那么最后一步就是如何解决这个间距的问题。
拉伸父元素,隐藏尾部的间隙
我们给list再套一个元素,让list在其父元素下拉伸,刚好隐藏掉多余的部分。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
< div class = "wrapper" > < ul class = "list" > < li > < div class = "content" ></ div > </ li > < li > < div class = "content" ></ div > </ li > < li > < div class = "content" ></ div > </ li > < li > < div class = "content" ></ div > </ li > < li > < div class = "content" ></ div > </ li > </ ul > </ div > |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
.wrapper{ width : 800px ; overflow : hidden ; } .list{ overflow : hidden ; margin-right : -10px ; } .list li{ width : 20% ; height : 100px ; float : left ; } .content{ margin-right : 10px ; } |
可以查看实际效果,最终能实现我们开头所展示的效果!且这种布局方式有很多的扩展性,如果一行是4个,那么只需要把每个元素的宽设置为 25%,且在元素的个数中减去一个就行。
2023-03-06
css3鼠标滑过实现动画线条边框2023-03-06
css scroll-snap控制滚动元素的实现2023-03-06
CSS实现多层嵌套列表自动编号的示例代码传统的灰色纯色边框你是不是觉得太难看了?你是否想设计一些精美的边框,例如渐变、圆角、彩色的边框?那你来对地方了,本文将介绍如何用纯CSS就能实现具有渐变和圆角的彩色边框...
2023-03-06
今天给大家带来一个如何实现圆角三角形的方案,这个方案虽然可以实现,但是也是借助拼凑等方式来实现的,假如想一个div来实现圆角三角形,还是比较困难的。之前文章讲了如何实现对话框,里面介绍了三角形的实现方式。今天讲讲...
2023-03-06