这里内容区域
内容1
内容2
之前HTML 页面的布局基本上都是通过 Flexbox 来实现的,能轻松的解决复杂的 Web 布局。 现在又出现了一个构建 HTML 最佳布局体系的新竞争者。就是强大的CSS Grid 布局。
特点:
- 固定和灵活的轨道尺寸;
- 可以使用行号,名称或通过定位网格区域将项目放置在网格上的精确位置;
- 可以将多个项目放入网格单元格或区域中,它们可以彼此部分重叠。
缺点:
兼容性比较差。
简单画一张图:
flex布局:
grid布局:
网格元素的垂直线方向称为列。
网格元素的水平线方向称为行。
网格间距指的是两个网格单元之间的网格横向间距或网格纵向间距。
我们可以使用以下属性给元素调整间隙的大小
- grid-column-gap
- grid-row-gap
- grid-gap
我们之前使用的弹性布局 一次只能处理一个维度上的元素布局,一行或者一列。
而现在的grid布局(网格布局)可以更自由的去设置一个容器所站的位置
例如:
如果使用flex布局去实现排版方法就需要嵌套很多个div去一块一块的区分这些
而现在使用grid布局的话,可以省下很多div的布局,直接将元素所站的位置区分开
使用grid布局实现图中排版:
grid 1234567
我们只需要在父元素中添加display:grid;属性,其元素下的子元素就会跟着变
fr:他是grid布局中的专属属性,用来平均分配容器所占位置
如图所示,这种布局方式使用弹性布局来实现相对来说是比较麻烦的,但我们使用grid布局就简单很多了
代码如下:
Grid 这是头部导航 这里内容区域
内容1
内容2
grid布局属性:
参考某教程:grid布局
Grid 布局与 Flex 布局有一定的相似性,都可以指定容器内部多个项目的位置。但是,它们也存在重大区别。
Grid 可以做Flexbox做不了的事,Flexbox 比 Grid 兼容性更好,他们可以共同工作。Grid item可以成为flexbox容器,flex item可以成为grid 容器。
可以根据业务场景需要选择相应布局。
上一篇:【王道数据结构】第八章 | 排序