浅谈CSS 栅格系统布局原理分析

2020-05-11 18:27:23易采站长站整理

.pure-u-2-24,.pure-u-1-12 { width: 8.3333%; }
.pure-u-3-24,.pure-u-1-8 { width: 12.5000%; }
.pure-u-4-24,.pure-u-1-6 { width: 16.6667%; }
.pure-u-5-24 { width: 20.8333%; }
...

不过它是不支持偏移和指定顺序的排版。

三、Foundation

fundation的栅格系统原理其实是和bootstrap@4.0版本如出一辙,都是采用伸缩布局的方式,最大支持12等分的栅格:


.grid-x {
display: -webkit-box;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-box-orient: horizontal;
-webkit-box-direction: normal;
-webkit-flex-flow: row wrap;
-ms-flex-flow: row wrap;
flex-flow: row wrap;
}

.grid-x > .small-1 { width: 8.33333%; }
.grid-x > .small-2 { width: 16.66667%; }
.grid-x > .small-3 { width: 25%; }
...
.grid-x > .small-12 { width: 100%; }

四、总结

UI框架栅格系统实现方式基本为三种:

1. 纯伸缩布局flex方式: 这种方式对古老的IE浏览器支持性不是很好,所以一般出现在技术比较激进的框架上,如Bootstrap@4.0,Foundation,基于React的antDesign,基于Vue的ElementUI 等等。
2. 浮动方式:这种方式是为了向下兼容IE低版本浏览器,比如用处很广的Bootstrap@3.x版本。
3. 伸缩和行内结合的方式:雅虎的Pure。