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 是 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 布局强大
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