ディスカッション:CSS3、柔軟なポーチをレイアウト

A、CSS3弾性箱

1.柔軟なCSS3ボックスは、新たなレイアウトパターンです。

ページは、画面サイズおよび要素のデバイスタイプ別に適応する必要がある2.CSS3柔軟ポーチ(フレキシブルボックスまたはフレキシボックス)が、その場合、適切な動作のレイアウトを確保しなければなりません。

3.空白のサブ要素、整列および分布の容器を配置するためのより効率的な方法を提供するために、柔軟ポーチレイアウトモデルを導入する目的。

第二に、ブラウザのサポート

1.表中の数字は、ブラウザプロパティの最初のバージョンのサポートを表明しました。

2. -webkit-は、ブラウザの数や-moz-接頭辞を指定した後に続きます。

三、CSS3弾性箱の中身

弾性カセット(フレックス容器)と、弾性サブ要素(フレックスアイテム)組成1.柔軟な容器。

インラインフレックス、又はフレックス弾性容器として定義されるの表示属性値を設定することにより2フレキシブルコンテナ。

前記フレキシブルコンテナは、サブ内の1つ以上の弾性要素を含みます。

注意:

及び外側弾性素子1弾性サブコンテナが正常にレンダリングされます。柔軟なボックスは、サブ弾性コンテナ内の弾性要素をレイアウトする方法を定義します。

前記弾性要素は、通常、弾性ボックスの副表示ラインです。デフォルトでは、各コンテナは一行だけです。

左から右に3以下に示した弾性要素のサブ要素は、単一の行に表示されます:

<!DOCTYPE html>
<html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>FLEX</title> <style> .flex-container { display: flex; flex-direction: row; flex-wrap: wrap; width: 1200px; height: 640px; background-color: lightsteelblue; } .flex-container .flex-item { width: 320px; height: 240px; margin: 10px; background-color:lightsalmon; } </style> </head> <body> <div class="flex-container"> <div class="flex-item"></div> <div class="flex-item"></div> <div class="flex-item"></div> </div> </body> </html>

四、CSS3弾性特性の共通ボックス

プロパティ 説明
表示 HTML要素のタイプは、ボックスを指定しました。
フレックス方向 弾性コンテナ要素の配置中性子を指定
フレックスラップ 親コンテナを越えて弾性ラップボックスサブ要素かどうか
フレックスフロー フレックス方向とフレックスラップ速記
ALIGN-アイテム 軸(縦)方向の弾性要素に配置されたカートリッジ側アライメント
ALIGN-コンテンツ フレックスラッププロパティは、ALIGN-アイテムと同様の挙動を変更するが、サブエレメントが整列配置が、配置された列に整列していません
正当化コンテンツ 弾性要素は、カセット軸(横軸)方向に整列しています


1.フレックスdirectionプロパティ

プロジェクトの方向性を決定します。

注:要素は弾性要素ボックスオブジェクトではない場合、属性方向が無効に曲がります。

.flex-container { flex-direction: row | row-reverse | column | column-reverse; }
 
 

プロパティ値:

説明
row 默认值。元素将水平显示,正如一个行一样。
row-reverse 与 row 相同,但是以相反的顺序。
column 元素将垂直显示,正如一个列一样。
column-reverse 与 column 相同,但是以相反的顺序。

2. flex-wrap 属性

flex-wrap 属性规定flex容器是单行或者多行,同时横轴的方向决定了新行堆叠的方向。

描述
nowrap 默认值。规定元素不拆行或不拆列。
wrap 规定元素在必要的时候拆行或拆列。
wrap-reverse 规定元素在必要的时候拆行或拆列,但是以相反的顺序。
 
.flex-container flex-wrap: nowrap | wrap | wrap-reverse}

可以取三个值:
(1) nowrap (默认):不换行。

 
 

(2)wrap:换行,第一行在上方。

 
 

(3)wrap-reverse:换行,第一行在下方。

 
 

3. flex-flow 属性

flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。

.flex-container flex-flow: <flex-direction> <flex-wrap> }

4. align-items属性

align-items 属性定义flex子项在flex容器的当前行的侧轴(纵轴)方向上的对齐方式。

描述
stretch 默认值。项目被拉伸以适应容器。
center 项目位于容器的中心。
flex-start 项目位于容器的开头。
flex-end 项目位于容器的结尾。
baseline 项目位于容器的基线上。
 

5. justify-content属性

justify-content 用于设置或检索弹性盒子元素在主轴(横轴)方向上的对齐方式。

描述
flex-start 默认值。项目位于容器的开头。
flex-end 项目位于容器的结尾。
center 项目位于容器的中心。
space-between 项目位于各行之间留有空白的容器内。
space-around 项目位于各行之前、之间、之后都留有空白的容器内。
 

五、弹性子元素属性

属性 描述
order 设置弹性盒子的子元素排列顺序。
flex-grow 设置或检索弹性盒子元素的扩展比率。
flex-shrink 指定了 flex 元素的收缩规则。flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值。
flex-basis 用于设置或检索弹性盒伸缩基准值。
flex 设置弹性盒子的子元素如何分配空间。
align-self 在弹性子元素上使用。覆盖容器的 align-items 属性。

1. order属性

.flex-container .flex-item order: <integer>}

<integer>:用整数值来定义排列顺序,数值小的排在前面。可以为负值,默认为0。

2. flex-grow属性

.flex-container .flex-item flex-grow: <integer>}

<integer>:一个数字,规定项目将相对于其他灵活的项目进行扩展的量。默认值是 0。

 
 

3. flex-shrink属性

.flex-container .flex-item flex-shrink: <integer>}

<integer>:一个数字,规定项目将相对于其他灵活的项目进行收缩的量。默认值是 1。


 
 

4. flex-basis属性

.flex-container .flex-item flex-basis: <integer> | auto}

<integer>:一个长度单位或者一个百分比,规定元素的初始长度。
auto:默认值。长度等于元素的长度。如果该项目未指定长度,则长度将根据内容决定。

5. flex属性

flex 属性用于设置或检索弹性盒模型对象的子元素如何分配空间。

flex 属性是 flex-grow、flex-shrink 和 flex-basis 属性的简写属性。

.flex-container .flex-item flex: flex-grow flex-shrink flex-basis | auto | initial | inherit}
描述
flex-grow 一个数字,规定项目将相对于其他元素进行扩展的量。
flex-shrink 一个数字,规定项目将相对于其他元素进行收缩的量。
flex-basis 项目的长度。合法值:"auto"、"inherit" 或一个后跟 "%"、"px"、"em" 或任何其他长度单位的数字。
auto 与 1 1 auto 相同。
none 与 0 0 auto 相同。
initial 设置该属性为它的默认值,即为 0 1 auto。
inherit 从父元素继承该属性。

6. align-self属性

.flex-container .flex-item { align-self: auto | stretch | center | flex-start | flex-end | baseline | initial | inherit; }

描述
auto 默认值。元素继承了它的父容器的 align-items 属性。如果没有父容器则为 "stretch"。
stretch 元素被拉伸以适应容器。
center 元素位于容器的中心。
flex-start 元素位于容器的开头。
flex-end 元素位于容器的结尾。
baseline 元素位于容器的基线上。
initial 设置该属性为它的默认值。
inherit 从父元素继承该属性。
 
 

取值参考 align-items即可


资料参考链接:



 

おすすめ

転載: www.cnblogs.com/meijifu/p/12167617.html