flex与grid布局

REL属性用于定义链接的文件和HTML文档之间的关系

Trident内核:IE,MaxThon,TT,The Word,360,搜狗浏览器等。[又称为MSHTML]
Gecko内核:Netscape6及以上版本,FF,MozillaSuite/SeaMonkey等;
Presto内核:Opera7及以上。[Opera内核原为:Presto,现为:Blink]
Webkit内核:Safari,Chrome等。[Chrome的:Blink(Webkit的分支)]

flex布局-“弹性布局”

Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。
指定为 Flex 布局。

 .box{
            display: flex/inline-flex(行内元素使用 Flex 布局);
        }

Webkit 内核的浏览器,必须加上-webkit前缀。

 .box{
        display: -webkit-flex; /* Safari */
        display: flex;
    }

注意,[设为 Flex 布局以后,子元素的float、clear和vertical-align属性将失效。]

容器的属性
1、flex-direction属性–决定主轴的方向(即项目的排列方向)。
flex-direction: row(水平) | row-reverse(水平反向) | column | column-reverse;
2、flex-wrap属性–定义,如果一条轴线排不下,如何换行。
flex-wrap: nowrap | wrap | wrap-reverse;
3、flex-flow属性–flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。

4、justify-content属性–定义了项目在主轴上的对齐方式。
justify-content: flex-start | flex-end | center | space-between | space-around;
flex-start(默认值):左对齐
flex-end:右对齐
center: 居中
space-between:两端对齐,项目之间的间隔都相等。
space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。

5、align-items属性–定义项目在交叉轴上如何对齐。
align-items: flex-start | flex-end | center | baseline | stretch;
flex-start:交叉轴的起点对齐。
flex-end:交叉轴的终点对齐。
center:交叉轴的中点对齐。
baseline: 项目的第一行文字的基线对齐。
stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。

6、align-content属性–定义了多根轴线(多行)的对齐方式。如果项目只有一根轴线,该属性不起作用
align-content: flex-start | flex-end | center | space-between | space-around | stretch;

项目的属性
1、order属性–定义项目的排列顺序。数值越小,排列越靠前,默认为0。
2、flex-grow属性–定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。
3、flex-shrink属性–定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。
4、flex-basis属性–定义了在分配多余空间之前,项目占据的主轴空间(main size)。浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项目的本来大小。
**** 5、flex属性–flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选;
该属性有两个快捷值:auto (1 1 auto) 和 none (0 0 auto)。
6、align-self属性–允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。
align-self: auto | flex-start | flex-end | center | baseline | stretch;

Flex 布局与grid布局区别:
Flex 布局是轴线布局,只能指定"项目"针对轴线的位置,可以看作是一维布局。Grid 布局则是将容器划分成"行"和"列",产生单元格,然后指定"项目所在"的单元格,可以看作是二维布局。Grid 布局远比 Flex 布局强大

grid布局-“网格布局”

div {
    display: grid/inline-grid(容器元素设为行内元素);
}

容器的属性
grid-template-columns 属性:定义每一列的列宽(只有多少个就设有几列)
grid-template-rows 属性:定义每一行的行高
----repeat()-接受两个参数,第一个参数是重复的次数(上例是3),第二个参数是所要重复的值。
例:

.container {
                    display: grid;
                    grid-template-columns: repeat(3, 100px 20px);//相当于grid-template-columns:100px 20px 100px 20px;
                    grid-template-rows: repeat(3, 33.33%);
                }

minmax()函数产生一个长度范围,表示长度就在这个范围之中。它接受两个参数,分别为最小值和最大值。
例:

>  grid-template-columns: 1fr 1fr minmax(100px, 1fr);//minmax(100px,
> 1fr)表示列宽不小于100px,不大于1fr

auto-fill 关键字

grid-template-columns: repeat(auto-fill, 100px);//每列100px,自动排列直至容器排满

fr 关键字—(如果两列的宽度分别为1fr和2fr,就表示后者是前者的两倍。)

grid-template-columns: 1fr 1fr 1fr;//3列相同大小

auto 关键字 表示由浏览器自己决定长度。

grid-template-columns: 100px auto 100px;//第二列自动填满

----"[]" 属性里面,还可以使用方括号,指定每一根网格线的名字,方便以后的引用。(允许同一根线有多个名字,比如[fifth-line row-5])

> grid-template-columns: [c1] 100px [c2] 100px [c3] auto
> [c4];//(该容器内有3列因此有4根垂直网格线)

grid-row-gap(新写法:row-gap) 属性:设置行与行的间隔(行间距)
grid-column-gap(新写法:column-gap) 属性:列与列的间隔(列间距)
****grid-gap(新写法:gap) 属性:grid-column-gap和grid-row-gap的合并简写形式

grid-template-areas属性用于定义区域。区域由单个或多个单元格组成

>     grid-template-areas: 'a b c'
>                                  'd e f'
>                                  'g . h';//划分出9个单元格,定名为a到h的九个区域,分别对应这九个单元格

合并区域:使用同一域名;某些区域不需要利用,则使用"点"(.)表示。
布局实例

> grid-template-areas: "header header header"
>                                  "main main sidebar"
>                                  "footer footer footer";
>         grid-auto-flow 属性:自动排列  值:row/column/row dense/column dense
>             row dense,表示"先行后列",并且尽可能紧密填满,尽量不出现空格
>             column dense,表示"先列后行",并且尽量填满空格

justify-items 属性:设置单元格内容的水平位置(左中右)
align-items 属性:设置单元格内容的垂直位置(上中下)
值:

start:对齐单元格的起始边缘。
end:对齐单元格的结束边缘。
center:单元格内部居中。
stretch:拉伸,占满单元格的整个宽度(默认值)


****place-items 属性:是align-items属性和justify-items属性的合并简写

justify-content 属性:是整个内容区域在容器里面的水平位置(左中右)
align-content 属性:是整个内容区域的垂直位置(上中下)

值:start - 对齐容器的起始边框
end - 对齐容器的结束边框。
center - 容器内部居中。
stretch - 项目大小没有指定时,拉伸占据整个网格容器。
space-around - 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与容器边框的间隔大一倍
space-between - 项目与项目的间隔相等,项目与容器边框之间没有间隔
space-evenly - 项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔

****place-content属性是align-content属性和justify-content属性的合并简写

grid-auto-columns 属性
grid-auto-rows 属性
用来设置,浏览器自动创建的多余网格的列宽和行高(有时候,一些项目的指定位置,在现有网格的外部;这时,浏览器会自动生成多余的网格)
不指定这两个属性时,浏览器完全根据单元格内容的大小,决定新增网格的列宽和行高

grid-template 属性:是grid-template-columns、grid-template-rows和grid-template-areas这三个属性的合并简写形式。
grid 属性:是grid-template-rows、grid-template-columns、grid-template-areas、 grid-auto-rows、grid-auto-columns、rid-auto-flow这六个属性的合并简写形式

项目属性
grid-column-start 属性:左边框所在的垂直网格线
grid-column-end 属性:右边框所在的垂直网格线
****grid-column 属性:是grid-column-start和grid-column-end的合并简写形式
grid-row-start 属性:上边框所在的水平网格线
grid-row-end 属性:下边框所在的水平网格线
****grid-row属性是grid-row-start属性和grid-row-end的合并简写形式
指定项目的位置,具体方法就是指定项目的四个边框,分别定位在哪根网格线。

>  .item-1 {
>                     grid-column-start: 2;
>                     grid-column-end: 4;
>                     //相当于grid-column: 2 / 4;
>                 }//项目的左边框是第二根垂直网格线,右边框是第四根垂直网格线

除了指定为第几个网格线,还可以指定为网格线的名字

>   grid-column-start: header-start;
>                 grid-column-end: header-end;

span关键字,表示"跨越",即左右边框(上下边框)之间跨越多少个网格

grid-column-start: span 2;//项目的左边框距离右边框跨越2个网格。

********grid-area属性指定项目放在哪一个区域
grid-area: e(域名);
还可用作grid-row-start、grid-column-start、grid-row-end、grid-column-end的合并简写形式,直接指定项目的位置
grid-area: / / /
justify-self 属性,
align-self 属性,
place-self 属性:设置单元格内容的水平/垂直位置,只作用于单个项目,跟justify/align/place-items属性的用法完全一致

flex更多实例:http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html?utm_source=tuicool

grid更多实例:http://www.ruanyifeng.com/blog/2019/03/grid-layout-tutorial.html

你可能感兴趣的:(学习笔记)