0

0

css网格布局(grid)的常用属性介绍

青灯夜游

青灯夜游

发布时间:2021-01-02 18:04:17

|

4414人浏览过

|

来源于csdn

转载

本篇文章给大家介绍一下网格布局(grid)的常用属性。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

css网格布局(grid)的常用属性介绍

教程推荐:css视频教程

和flex布局不同的是,网格布局(grid)是一个二维的布局,可以创建任意行列的布局。 

首先来介绍几个概念; 

立即学习前端免费学习笔记(深入)”;

想象一个三行三列的布局,网格线就是构成网格所有的线条,三行三列的布局每行就会有4条网格线。 

网格轨道就是相邻两条平行的网格线之间的部分。 

和flex布局一样,他会有父容器和子项目,在这儿我们称为网格容器和网格项。 

接下来,我们从网格容器到网格项的各个基本属性来介绍网格布局。

1.png

网格容器 

网格容器是决定将网格分为几行几列,所以首先实现网格布局就要使该容器具有以下几个属性:

 display: grid;    grid-template-columns    grid-template-rows    grid-gap     grid-template-areas    grid-auto-flow: dense | row(default) | column    justify-items: start|end|center|stretch(default)     align-items:     start|end|center|stretch(default)    grid-auto-columns: 

网格布局的父容器基本属性就是以上几个。 

  • display:grid 

表示为网格布局,和flex布局中的display:flex意义相同,同样该属性还可以取值:inline-grid和subgrid

  • grid-template-columns 

创建网格的列数,除了百分比的形式之外,还支持各种单位的组合形式,比如 grid-template-columns: 100px 20% 1em 1vw 20%; 

但是有个repeate函数可以简化相同的值,比如grid-template-columns: repeat(5, 20%)表示5个20%的宽度,和例子中的意义完全相同。 

fr用于等分剩余空间,它的大小是将该属性上的所有可计算的值(包括各种单位,百分比)除去后,剩余空间的大小。 

推荐使用fr。它也会自动计算除了grid-gap之外其余的部分。 

如 grid-template-columns:100px 1fr 2fr repeat(2, 20%)。同样的5列布局,其中的 1fr 表示宽度为总宽度减去左边的100px和右侧两列的20%之后剩余的部分除以三。即第二列的宽度是将会是第三列的一半。 

  • grid-template-rows 

属性值和grid-template-columns的属性值完全一样。 

  • grid-template 

是grid-template-rows和grid-template-columns的缩写形式,属性值的写法为 

grid-template: 1fr 50px/1fr 4fr; //为行数/列数的形式,

该代码表示两行两列的布局,第一行的高度为底行的50px确定之后剩下的高度。第一列的宽度为将该容器分为五等分,第一列占据一份,第二列占据四份。 

  • grid-gap 

可以取一或两个值,表示行列之间的间隙。

  • grid-template-areas 

通过引用 grid-area 属性指定的 网格区域(Grid Area) 名称来定义网格模板。重复网格区域的名称导致内容跨越这些单元格。一个点号(.)代表一个空的网格单元。这个语法本身可视作网格的可视化结构。 

  • grid-template-areas: 

“header header header header” 

“main main . sidebar” 

“footer footer footer footer”; 

2.png

汕头吧网上商城系统
汕头吧网上商城系统

特点与优点:1.界面布局合理美观,浏览方便,更具商城站点的风格;2.前后台功能强大好用,如三级分类、竞拍、排行榜、特价、促销、积分等;3.更具人性化,如定单反馈、会员与VIP分别显示不同的售价等;4.优化程序代码,执行速度快速;5.不错的短信联络管理员以及留言本的悄悄话功能等。功能介绍:商品的添加、修改、删除。 管理商品的订单及修改订单状态和网友对商品的评论。管理网站前台用户,可进行修改、删除操作

下载
  • grid-auto-flow: 

    • row:告诉自动布局算法依次填充每行,根据需要添加新行 

    • column:告诉自动布局算法依次填入每列,根据需要添加新列 

    • dense:告诉自动布局算法在稍后出现较小的网格项时,尝试填充网格中较早的空缺

  • justify-items 

沿着 行轴线(row axis) 对齐 网格项(grid items) 内的内容 

  • align-items 

沿着 列轴线(row axis) 对齐 网格项(grid items) 内的内容 

  • grid-auto-columns: 

隐式网格的宽度 

  • grid-auto-rows: 

隐式网格的高度 

网格项 

网格项表示网格内部的直接子元素,不包括子元素的子元素。 

常用属性: 

  • grid-column-start: 列网格线 开始, 

  • grid-column-end: 列网格线 结束 

  • grid-column: start/end | start/span count 

  • order: 与z-index的属性相同,表示层叠的位置。

  • grid-area: 网格名,在使用grid-template-areas时比较有用。

  • justify-self: 单个网格项在行轴线的对齐方式

  • align-self: 单个网格项在列轴线的对齐方式