• 技术文章 >web前端 >css教程

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

    青灯夜游青灯夜游2021-01-02 18:04:17转载1589
    本篇文章给大家介绍一下网格布局(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:

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

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

    创建网格的列数,除了百分比的形式之外,还支持各种单位的组合形式,比如 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-columns的属性值完全一样。

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

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

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

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

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

    “header header header header”

    “main main . sidebar”

    “footer footer footer footer”;

    2.png

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

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

    隐式网格的宽度

    隐式网格的高度

    网格项

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

    常用属性:

    <div class='container'>
            <div class='child'></div>
        </div>
        <style>
        .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)的常用属性介绍的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:csdn,如有侵犯,请联系admin@php.cn删除
    专题推荐:css 网格布局 grid
    上一篇:css font控制字体的多种变换 下一篇:css如何写二级下拉菜单

    相关文章推荐

    • 邮件不支持css怎么办• 利用css实现一个简单的对号效果• css图片不让选中状态如何实现• css important 是什么• 了解CSS的选择器优先级和!important权重

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网