时间:2021-05-08
flex 从 2009 年推出到现在,已经得到了几乎所有浏览器的支持。作为一种简便的、响应式的布局方案,flex 给我们的布局开发带来了很多便利。
justify-content 属性是 flex 布局中很常用的属性,定义了子元素在主轴上的对齐方式。它有 flex-start | flex-end | center | space-between | space-around | space-evenly 等属性。
但是,笔者在一次开发中发现 space-evenly 在使用中会面临兼容性问题,在 iPhone 5s 上测试时发现设定了 justify-content: space-evenly 的容器中的子元素并没有按期望中的一样沿着主轴均匀分布,而是都挤在了左边。
.container { display: flex; justify-content: space-evenly;}查看 Can I use space-evenly? 发现,space-evenly 的支持范围确实相对较小。
MDN 上对 space-evenly 属性的定义是:
flex 项都沿着主轴均匀分布在指定的对齐容器中。相邻 flex 项之间的间距,主轴起始位置到第一个 flex 项的间距,主轴结束位置到最后一个 flex 项的间距,都完全一样。
为了解决这个问题,笔者想到了两种方式:
flex-grow 指定了容器的剩余空间应该如何分配给子元素。
让所有子元素同时拥有 flex-grow: 1 属性,它们会等分容器的空间,也就实现了「均匀分布、间距相等」的效果。
另外一种方式是利用和 space-evenly 属性类似的 space-between。这两个属性很接近,而 space-between 也基本不会遇到兼容性问题。
不同的是,在 space-evenly 下,每个子元素的两侧都有同样的空间,而在 space-between 下,每行第一个元素与行首对齐,每行最后一个元素与行尾对齐。
假设在一个容器中有五个子元素,用那么这两个属性的差别可以简单表示成:
// space-evenly|--子--子--子--子--子--|// space-between|子--子--子--子--子|也就是说,space-evenly 会比 space-between 多了两边的两个空隙,而 space-between 的第一个和最后一个子元素是紧贴容器边缘的。
为了填补这个差异,我们可以用两个伪元素,来让容器在设定为 space-between 的时候,拥有七个子元素,也就拥有了「六个空隙」:
|伪--子--子--子--子--子--伪|
代码:
.container { display: flex; justify-content: space-between; &:before, &:after { content: ''; display: block; }}到此这篇关于浅谈解决space-evenly兼容性问题的两种方法的文章就介绍到这了,更多相关space-evenly兼容性内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
最近有Mac用户发现mac存在跨平台字体兼容性问题,那么mac跨平台字体兼容性问题怎么解决呢?跟着小编一起来看看mac跨平台字体兼容性问题解决方案。mac跨平台
解决浏览器兼容性问题,首先要把设计语言升级到最新的版本,通常最新的CMS都遵循HT-ML5、CSS3等最新的技术标准,很大程度上减少了兼容性问题的产生。另外,在
正确认识AGP接口的兼容性问题对解决因接口兼容性问题导致的故障很有意义。简单说AGP8X规格与旧有的AGP1X/2X模式不兼容,大多数AGP4X显卡则可以兼
电脑蓝屏的解决方法如下:是否添加过内存条或存储设备 1.是-->移除内存/存储设备。 问题解决-->硬件兼容性问题。 问题未解决-->此问题发生之前是否安
电脑蓝屏的解决方法如下:是否添加过内存条或存储设备 1.是-->移除内存/存储设备。 问题解决-->硬件兼容性问题。 问题未解决-->此问题发生之前是否安