CSS Grid 网格布局简要说明

grid网格布局,是一个二维系统,可以像表格一样将页面容器分割成一块一块的区域,定义子元素的排布和位置。

简单使用: 对父元素设置dispay:grid ;grid-template-colums和grid-template-rows来设置几行几列

1. grid-template-columns/grid-template-rows属性

使用以空格分隔来定义网格的行和列,它们之间的空格表示网格线

复制代码
.container{
       display:grid;
       grid-template-columns:  50px auto 50px ;
       grid-template-rows: 25% 100px auto;
}

上面代码设置的是一个三行三列的网格,具体行高和列宽即为设置的值

2 fr属性

fr单元等分网格容器剩余可用空间来设置网络的大小

css 复制代码
.container{
	grid-complate-columns: 1fr 1fr 1fr;
}

上面代码将每个网格项设置为网格容器宽度的三分之一:

3 grid-template-areas属性

grid-area属性可以定义网络模板,通过引用grid-area属性指定的网格区域的名称来定义网络模板,重复网格区域的名称会使内容扩展到这些单元格。

grid-area-name:由网格项grid-area指定网格区域的名称

.:代表空网格单元

none:不定义网格区域

css 复制代码
.area-a{
	grid-area: head;
}
.area-b{
	grid-area: body;
}
.area-c {
	grid-area: sidebar;
}
.area-d {
	grid-area: foot;
}
.container{
	grid-template-columns: 50px 50px 50px 50px;
	grid-template-rows: auto;
	grid-template-areas:
		"head head head head"
		"body body . sidebar"
		"foot foot foot foot";
}

上面代码创建如下网格:


| head | head | head | head |


| body | empty----grid | side |


| foot | foot | foot | foot |


4 grid-template属性

grid-template-columns、grid-template-rows、grid-template-areas的简写

与flex区别

  1. flex是一维布局,适合做局部布局,比如导航栏组件。
  2. grid是二维布局,通常用于整个页面的规划。
  3. grid适合框架布局,flex适合细节布局
相关推荐
xump18 分钟前
如何在DevTools选中调试一个实时交互才能显示的元素样式
前端·javascript·css
折翅嘀皇虫19 分钟前
fastdds.type_propagation 详解
java·服务器·前端
Front_Yue20 分钟前
深入探究跨域请求及其解决方案
前端·javascript
wordbaby21 分钟前
React Native 进阶实战:基于 Server-Driven UI 的动态表单架构设计
前端·react native·react.js
抱琴_22 分钟前
【Vue3】我用 Vue 封装了个 ECharts Hooks,同事看了直接拿去复用
前端·vue.js
风止何安啊24 分钟前
JS 里的 “变量租房记”:闭包是咋把变量 “扣” 下来的?
前端·javascript·node.js
Danny_FD29 分钟前
用 ECharts markLine 标注节假日
前端·echarts
程序员西西30 分钟前
SpringBoot无感刷新Token实战指南
java·开发语言·前端·后端·计算机·程序员
烛阴30 分钟前
Luban集成CocosCreator完整教程
前端·typescript·cocos creator
有点笨的蛋30 分钟前
深入理解 JavaScript 原型机制:构造函数、原型对象与原型链
前端·javascript