当前位置: 首页 > news >正文

grid网格布局

使用flex布局的痛点

如果使用justify-content: space-between;让子元素两端对齐,自动分配中间间距,假设一行4个,如果每一行都是4的倍数那没任何问题,但如果最后一行是2、3个的时候就会出现下面的状况:

/* flex布局 两端对齐 */
display: flex;
flex-wrap: wrap;
justify-content: space-between;
常见flex布局
常见flex布局

 如何想让最后一行左对齐是有办法的,大家可以自行去搜索办法,能实现但是操作起来有些麻烦,但是如果这种布局使用grid布局的话,就会变的非常容易

同样的布局,将flex改为grid 
/* grid布局 两端对齐,最后一行左对齐*/
display: grid;
grid-template-columns: 1fr 1fr 1fr 1fr;
gap: 30px;   
解释一下上面的代码:

display:grid 是转为网格布局,这个是必须的
grid-template-columns:1fr | px 这是将网格分为几列,1fr是自适配单位,可以当成栅格
gap:30px 这是网格四周的间隔
注意:这三个属性是给父容器添加的,子元素,可以不用设置宽度,也不用设置margin间距即可完成如下布局

grid布局

看,上面的grip布局,最后一行不是4的倍数,但是可以左对齐,不会像flex布局一样的bug。 

 

深入了解一下grid-template-columns属性
独占一行
grid-template-columns: 1fr;
一行分为两列  多列只需多写几个1fr
grid-template-columns: 1fr 1fr;
 中间固定200px,两边自动平均分配
grid-template-columns: 1fr 200px 1fr;
 如果5列的值相同,可以使用repeat()函数,grid-template-columns: repeat(5,1fr)当然将1fr换成固定的px尺寸也可以
grid-template-columns: 1fr 1fr 1fr 1fr 1fr;grid-template-columns: repeat(5,1fr)
响应式布局,auto-fill主轴上指定的宽度或者重复次数是最大可能的正整数,minmax最小值255px、最大值1fr代表剩余空间
grid-template-columns: repeat(auto-fill, minmax(255px, 1fr)); 

注意:实现这种响应式布局,一定要注意父容器不能使用固定宽度,可以将父容器改为如:80%,这样就能根据屏幕的宽度,自动展示一行展示几个了。

grid-row和grid-column可以控制某个元素占领几份

注意是给开始的盒子设置样式,并非所有

.layout .box1{grid-row: 1/3;grid-column: 1/3;
}

以grid-row行为例,从第几列开始 / 第几列+想占几个;

 

http://www.xdnf.cn/news/709309.html

相关文章:

  • day40 python图像数据与显存
  • 嵌入式鸿蒙系统中水平和垂直以及图片调用方法
  • 纯数据挖掘也能发Microbiome?
  • pikachu靶场通关笔记07 XSS关卡03-存储型XSS
  • DeepSeek 赋能卫星遥感:AI 驱动数据分析新范式
  • ubuntu 22.04安装k8s高可用集群
  • 使用 Azure DevOps 管道部署到本地服务器
  • Java 中的 final关键字详解
  • (四) 本地YARN集群的部署
  • 2022 RoboCom 世界机器人开发者大赛(睿抗 caip) -高职组(国赛)解题报告 | 科学家
  • 从微积分到集合论(1630-1910)(历史简介)——第3章——数学分析的出现及其基础性进展(1780-1880)(I.Grattan-Guinness)
  • 基于React和TypeScript的金融市场模拟器开发与模式分析
  • 关于智能体接入后端,在Apifox能够传参数给智能体的测试
  • 【科研绘图系列】R语言绘制GO term 富集分析图(enrichment barplot)
  • 西门子嵌入式学习笔记---(1)裸机和调度器开发
  • 人工智能赋能基础教育个性化学习的理论建构与实践探索
  • Opencv实用操作6 开运算 闭运算 梯度运算 礼帽 黑帽
  • [VMM]分享一个用SystemC编写的页表管理程序
  • GCN图神经网络的光伏功率预测
  • 德思特新闻 | 德思特与es:saar正式建立合作伙伴关系
  • 2025.05.28-华为暑期实习第一题-100分
  • 基于本地知识库的政务问答智能体
  • IDEA项目推送到远程仓库
  • 如何让 Git 停止跟踪文件?停止后又如何恢复跟踪?
  • node_modules包下载不下来
  • OpenCv高阶(二十)——dlib脸部轮廓绘制
  • LeetCode 3373.连接两棵树后最大目标节点数目 II:脑筋急转弯+广度优先搜索(黑白染色法)
  • React Native 实现抖音式图片滑动切换浏览组件-媲美抖音体验的滑动式流畅预览组件
  • [特殊字符] NAT映射类型详解:从基础原理到应用场景全解析
  • Python训练营打卡Day39