css设置水平排列

2024-10-31 09:43:15
推荐回答(2个)
回答1:

1、绝对定位+margin:auto



完全居中层1:


开发工具 【 WeX5 】: 高性能轻架构、开源免费、跨端、可视化


1234567891011121314151617181920212223242526

效果: 

实现原理:利用css定位规则,设置左右、上下方向定位为0,margin为auto,让css根据定位计算margin值,用hack的方式实现居中。居中块(绿色)的尺寸需要可控,因为css计算margin时也需要参考尺寸值,由于四周为0,所以自动计算的尺寸是与父容器一样的。无论是设置width、height或者是 max-height、max-width,都是让尺寸不会扩大到与父级一样。

2、绝对定位+margin反向偏移



完全居中方案二:


开发工具 【 WeX5 】: 高性能轻架构、开源免费、跨端、可视化


12345678910111213141516

效果: 

实现原理:由于top、left偏移了父对象的50%高度宽度,所以需要利用margin反向偏移居中块的50%宽高。而margin中不能使用百分比,因为百分比是针对父对象的,所以需要手动计算定值指定margin值。这个方案需要固定尺寸值,以此来计算margin反向偏向值,所以方案2比方案1稍差!

3、绝对定位+transform反向偏移



完全居中方案三:


开发工具 【 WeX5 】: 高性能轻架构、开源免费、跨端、可视化

12345678910111213141516

效果: 

实现原理:方案3与方案2原理一样!不同点是使用了transform来代替margin做反向偏移,由于transform的计算基准是元素本身,所以这里可以用50%来做反向偏移。这个方案也需要固定尺寸值,浏览器以此为基准来计算定位!

4、display:tabel




完全居中方案四:



123456789101112131415161718192021

效果: 

实现原理:方案4是实现效果比较好的,居中块的尺寸可以做包裹性,缺点是增加了一层table-cell层来实现垂直居中。方案4的居中块可以设置 max-height、max-width,而且居中块是可以具有垂直方向的包裹性的。水平方向由于是在table-cell里面的,所以会直接显示max-width,也就是宽度趋大。

5、display: inline-block



完全居中方案五:


开发工具 【 WeX5 】: 高性能轻架构、开源免费、跨端、可视化


12345678910111213141516171819202122232425262728

效果: 

实现原理:原理:利用inline-block的vertical-align: middle去对齐after伪元素,after伪元素的高度与父对象一样,就实现了高度方向的对齐。方案5实现效果更加好,居中块的尺寸可以做包裹性、自适应内容,兼容性也相当好。缺点是水平居中需要考虑inline-block间隔中的留白(代码换行符遗留问题。)。方案4的居中块可以设置 max-height、max-width,而且居中块是可以具有水平垂直两个方向的自适应。

6、display: flex-box



完全居中方案六:


开发工具 【 WeX5 】: 高性能轻架构、开源免费、跨端、可视化


1234567891011121314151617181920212223242526272829303132

效果: 

实现原理: flexbox布局。此乃布局终极大法,专治各种布局定位难题!优点:能解决各种排列布局问题,实现方式符合人类认知。缺点:PC端某些旧浏览器支持度不高。

回答2:

float就行了