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

本篇文章给大家介绍一下网格布局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

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: 单个网格项在列轴线的对齐方式

.container { display: grid; width: 580px; height: 580px; grid-gap: 3px; grid-template-rows: repeat(5, 1fr); grid-template-columns: repeat(5, 1fr); background-color: blanchedalmond; } .child { grid-column-start: 6; grid-column-end: 3; grid-row-start: 1; grid-row-end: 5; background: url(./babar.png); background-size: 116px 116px; order:1; }

3.png

在审查元素的时候毫不意外的发现该布局为五行五列的布局,上述的child中前四行代码属性的值都是以网格线的顺序为基准,前两行代码表示第六列网格线开始,到第三列网格线结束,即表示后三列。其中的start不一定要比end小。第三四行代码表示第一个网格线开始,第五个网格线结束,即表示前四行,四行代码综合起来就如图所示。 

当然,child中的前四行代码也可以简写成这样:

grid-row: 1/ 5;

grid-column: 6/ 3;

或者

grid-row: 1/ span 4; // 横向第一个网格线开始,以下的4个网格轨道

grid-column: 3/span 3; // 竖向第三条网格线开始,以后的3个网格轨道

甚至简写成这样

grid-area: 1/3/ span 4/span 3; 

更多编程相关知识,请访问:编程教学!!

以上就是css网格布局(grid)的常用属性介绍的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1617126.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 05:45:08
下一篇 2025年12月24日 05:45:16

相关推荐

  • css如何写二级下拉菜单

    css写二级下拉菜单的方法:首先创建一个HTML示例文件;然后使用css的display属性控制二级下拉菜单的显示与否;最后通过浏览器查看运行效果即可。 本教程操作环境:Dell G3电脑、Windows7系统、Chrome76.0&&CSS3版本。 推荐:《css视频教程》 纯CS…

    2025年12月24日
    000
  • 图片之间的间隔css怎么设置

    css设置图片之间的间隔的方法:首先新建一个html文件;然后创建一个div,并在div内使用img标签创建两张图片;最后使用margin属性设置两张图片之间的距离即可。 本教程操作环境:Dell G3电脑、Windows7系统、HTML5&&CSS3版本。 推荐:《css视频教程》…

    2025年12月24日 好文分享
    000
  • css如何添加flash

    css添加flash的方法:首先建立一个JS文件flash.js;然后在页面中调用下该文件;最后将flash的样式写在CSS中即可。 本文操作环境:Dell G3电脑、Windows7系统、HTML5&&CSS3版本。 推荐:《css视频教程》 具体问题: css 添加flash 立…

    2025年12月24日
    000
  • 如何解决webpack css url报错问题

    webpack css url报错是因为图片加载路径错误,其解决办法:首先打开相应的代码文件;然后打包样式中的背景图;最后重新添加publicPath即可。 本教程操作环境:Dell G3电脑、Windows7系统、webpack3.0&&css3版本。 推荐:《css视频教程》 w…

    2025年12月24日 好文分享
    000
  • css怎么去掉文字前的点

    css去掉文字前的点的方法:1、在相关的页面找到head部分,并写入代码为“ul li{list-style:none;}”;2、在li和ul内加入“list-style”即可。 本文操作环境:Windows7系统,Dell G3电脑,HTML5&&CSS3版。 推荐:《css视频教…

    好文分享 2025年12月24日
    000
  • css怎么实现平方

    css实现平方的方法:首先创建一个HTML示例文件;然后通过“mn”标签语法计算m的n次方即可。 本教程操作环境:windows7系统、HTML5&&CSS3版本,Dell G3电脑。 相关推荐:《css视频教程》 html/css实现平方表示法 需要使用标签 立即学习“前端免费学习…

    2025年12月24日
    000
  • css怎么给按钮加上超链接

    css给按钮加上超链接的方法:1、使用“window.location.href(‘url地址’)”方法让本页转向新的页面;2、使用“window.open(‘url’)”方法打开一个新的页面。 本教程操作环境:windows7系统、HTML5&amp…

    2025年12月24日
    000
  • 关于CSS margin的一些你需要知道的知识点

    教程推荐:css视频教程 当我们学习CSS时,我们大多数人学到的第一件事是CSS中盒子的各个部分的细节,这部分通过叫做 CSS盒、模型。“盒模型”中的元素之一是margin,即盒子周围的透明区域,它会将其他元素从盒子内容中推开。 CSS1中描述了 margin-top、margin-right、ma…

    2025年12月24日 好文分享
    000
  • css height:auto 不起作用怎么办

    css height:auto不起作用的解决办法:1、利用chrome查找被覆盖属性的父级css属性,并删除;2、将父元素加上“zoom:1;overflow:hidden;”语句即可。 本教程操作环境:windows7系统、Chrome76.0&&CSS3版本,Dell G3电脑。…

    2025年12月24日
    000
  • 利用css来画出各种样式不同的梯形

    首先我们要知道一下四个非常重要的样式: (学习视频分享:css视频教程) border-buttom:设置下边框 border-top: 立即学习“前端免费学习笔记(深入)”; border-left: border-right: .mask{ height: 0; width: 100px; bo…

    2025年12月24日 好文分享
    000
  • css a hover 不变色怎么办

    css a hover不变色是因为选择器的顺序写错了,其解决办法:首先打开相应的css文件;然后将hover写在link和visited之后以及active之前即可。 本教程操作环境:windows7系统、HTML5&&CSS3版本,Dell G3电脑。 相关推荐:《css视频教程》…

    2025年12月24日
    000
  • css子类选择器是什么

    在css中,类选择器是值“E > F”选择器,用于匹配E元素的所有一级子元素F;子类选择器仅仅指的是父元素的直接后代,大家可以理解为仅作用于第一代子元素,通过“>”进行选择。 本文操作环境:windows10系统、 如果从右向左读,选择器 h1 > strong 可以解释为“选择作…

    2025年12月24日
    000
  • css 什么是相对长度单位

    在css中,相对长度单位是根据与其他事物的关系来度量的长度单位,是没有固定值的。所度量的实际距离,可能会因为不在其控制之下的其他因素而改变,如屏幕分辨率、可视区域的宽高等等;并且,对于某些相对单位,其大小会因使用该单位的元素的不同而不同。 本教程操作环境:windows7系统、css3版、Dell …

    2025年12月24日
    000
  • 浅谈CSS元素显示模式

    推荐:css视频教程    在CSS中,根据元素显示模式的不同元素标签被分为了两类:行内元素(inline-level)、块级元素(block-level)。 1,首先介绍什么是行内元素,什么又是块级元素?   1.1,行内元素就是不会独占一行的元素,例如:span buis strong em i…

    2025年12月24日
    000
  • css如何把div修饰成圆

    css把div修饰成圆的方法:首先新建一个html文件;然后在body标签内输入“”;最后在head表里添加style标签,并添加“border-radius”属性即可。 本教程操作环境:Dell G3电脑、Windows7系统、HTML5&&CSS3版本。 推荐:《css视频教程》…

    2025年12月24日
    000
  • CSS中一个冒号(:)和两个冒号(::)的区别

    推荐:css视频教程 一个冒号是伪类,两个冒号是伪元素 伪类可以独立于文档的元素来分配样式,且可以分配给任何元素,逻辑上和功能上类类似,但是其是预定义的、不存在于文档树中且表达方式也不同,所以叫伪类。 伪元素所控制的内容和一个元素控制的内容一样,但是伪元素不存在于文档树中,不是真正的元素,所以叫伪元…

    2025年12月24日
    000
  • 怎么设置css字体单行居中

    设置css字体单行居中的方法:首先创建一个div;然后在div里写上一个p标签;最后通过设置“text-align: center;”属性实现单行居中即可。 本教程操作环境:Dell G3电脑、Windows7系统、HTML5&&CSS3版本。 css设置字体单行居中 1、首先为了便…

    2025年12月24日 好文分享
    000
  • 波浪的边框css怎么实现

    css实现波浪边框的方法:首先新建一个div,并给它一个类名;然后设置一个背景颜色,并将div设为白色;接着使用伪元素before进行设置,并插入有渐变颜色的形状;最后加上尺寸进行图形的分割,并增加三角形实现波浪效果即可。 本教程操作环境:Dell G3电脑、Windows7系统、HTML5&amp…

    2025年12月24日 好文分享
    000
  • CSS如何让背景图片不重复

    CSS让背景图片不重复的方法:首先新建一个html文件;然后输入一个div标签,并对这个标签添加一个class类;最后通过属性“background-repeat:no-repeat;”实现背景图片不重复即可。 本教程操作环境:Dell G3电脑、Windows7系统、HTML5&&…

    2025年12月24日 好文分享
    000
  • css td文字不换行如何实现

    css td文字不换行的实现方法:首先打开相应的css代码;然后为表格table与td标签设置“white-space:nowrap;”样式即可使表格内文字不换行。 本教程操作环境:Dell G3电脑、Windows7系统、HTML5&&CSS3版本。 css表格文字不换行的设置 很…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信