zoukankan      html  css  js  c++  java
  • display: grid

    grid网格布局,就是将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局
    如果把一个父级元素设置 display: grid 其中的子元素 会在控制台选中子元素 会看到 一个个虚线,这就是网格 如下图所示
     
     
     
    父元素设置
    display: grid // 默认是块级元素
    display: inline-grid // 默认是行内块元素
    注意:设置为grid后,子元素的float, display:inline-block,display:table-cell  等设置都无效了
     
    1. 行宽列宽
    grid-template-columns:   定义列数,每一列的列宽;(一排有几个div,每个div宽度是多少)
    grid-template-columns:   100px  100px  100px;   //代表有三列,每列是100px的宽度,也可以用百分比
    grid-template-rows:   每一行的行高;(每行div的高度是多少)
    grid-template-rows:100px  100px  100px;    //从上至下,每行高度为100px,如果有第四行,未设置就是其自身高度
    即:每一行的高度是一样,每一列的宽度是一样的,就像格子一样,就是网格布局
    多个值可以用 repeat 函数
    grid-template-columns:   100px  100px  100px;
    // 简写方法 即重复3次 每行高度100px
    grid-template-columns:repeat(3,100px);
    
    // 也可以是不固定的重复模式 
    grid-template-columns:repeat(2,100px 80px);  //重复两次100px 80px 的模式,就是4列=== grid-template-columns:100px  80px  100px 80px;
    repeat 第一个参数 重复几次
    注意: 后面如果是多个参数 第一个参数会重复 后边所有参数的次数
     
    2. 关键词: 
    1) auto-fill:
    如果容器大小不固定,网格大小固定,可以用关键词自动填充
    grid-template-columns:repeat(auto-fill,100px);//自动填充,每列100px宽度
    2)fr(fraction):倍数,
    如果有两列,1fr 2fr,后者就是前者的两倍
    grid-template-columns:1fr 2fr;
    grid-template-rows:50px 1fr 2fr;
     
    如图:第二列是第一列的2倍,填充整个容器的宽度
    对于行高,1fr就是自身内容的高度,第一行是50px 第二行是18px 第三行2倍36px,因为没有设置第四第五行,所以后面两行都是自身高度18px。
    3)minmax()
    grid-template-columns:1fr 5fr minmax(100px,1fr);
    解释:第一列是1fr,第二列是5fr,第三列最小值是100px,最大值是1fr。
    当1fr>=100px,比如容器是800px,那1fr就是114左右
    第一列是1fr=800/7,第二列是5fr,第三列是1fr
    当1fr<100px,比如容器是600px,则
      第一列是1f=(600-100)/6 ,第二列是5fr,第三列是100px
      4)auto
      grid-template-columns:100px auto 100px;
      3.网格线名称
      grid-template-columns:[c1] 100px [c2] 100px [c3] auto [c4];
      grid-template-rows: [r1] 100px [r2] 100px [r3] auto [r4];
      指定每一根网格线的名字,方便以后引用。也可以给多个名字如:[c1,c1a]
      4.间距
      row-gap:行间距
      column-gap:列间距
      简写:gap:20px 2opx; ,row-gap和column-gap的简写形式,可以省略第二个值,浏览器默认第二个等于第一个值
      grid-template-columns:repeat(3,1fr);
      gap:20px;
      grid-template:repeat(3,50px);
     
     
    5.区域
    grid-template-areas:指定区域,一个区域有单个或者多个单元格组成
    grid-template-areas:'a b c' 'd e f';
     
     
    6.放置顺序
    grid-auto-flow:网格默认的顺序是先行后列,默认值是row
    grid-auto-flow:column;
    grid-template: repeat(3,100px 70px)/repeat(2,1fr); //先行设置,后列设置




    7.单元格的水平垂直
    justify-items:设置单元格内容的水平位置(左中右) 
    align-items:设置单元格内容的垂直位置(上中下)    
    • start:对齐单元格的起始边缘。
    • end:对齐单元格的结束边缘。
    • center:单元格内部居中。
    • stretch:拉伸,占满单元格的整个宽度(默认值)。
    简写:place-items:align-items justify-itmel //先垂直位置,后水平位置
    place-items:center; //单元格的内容相对于单元格水平垂直居中
    8.整体内容的位置
    同上,justify-content:整体内容在容器里面的水平位置
    align-content:垂直位置
     
     
    子元素属性
    设置子元素上的属性
    属性说明
    grid-area属性还可用于为网格项指定名称。然后,可以通过网格容器的grid-template-areas属性引用命名网格项 。
    grid-column-start属性定义项目将从哪个列行开
    grid-column-end 哪跟竖线结束
    grid-row-start 哪跟横线开始
    grid-row-end 哪跟横线结束
    grid-row grid-row-start和grid-row-end的缩写
    grid-column grid-column-start和grid-column-end这两个属性的缩写方式
    grid-area grid-row和grid-column的缩写
    justify-self 设置单个子元素在其所在的小网格中的X轴排列方式
    align-self 设置单个子元素在其所在的小网格中的Y轴排列方式
    align-content 来设置整个网格在网格容器中的Y轴的排列方式
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
  • 相关阅读:
    vue 开发环境搭建
    签名算法
    MySQL explain执行计划优化
    查看运行时某个java对象占用JVM大小及通过idea查看java的内存占用情况
    jenkins 配置
    CSS布局
    《JavaScript 代码优化指南》
    JavaScript 跨域漫游
    iFrame 功能详解
    粘性的底部布局
  • 原文地址:https://www.cnblogs.com/maxiag/p/13407411.html
Copyright © 2011-2022 走看看