CSS display:flexの使い方(フレックスボックス)

本記事は広告が含まれる場合があります CSS

【CSS display:flex】フレックスボックスの使い方

フレックスボックス(フレキシブルボックス)は、CSSの新しいレイアウト技法で、HTMLブロックを横並びにすることができます。
 

フレックスボックスは、display:flexで実現でき、従来のfloatよりも柔軟なレイアウトを組むことができます。
 


 



フレックスボックス display:flexの使い方

フレックスボックス(フレキシブルボックス)は、CSSの新しいレイアウト技法で、HTMLブロックを横並びにすることができます。

display:flexを設定することで、cssのflexbox(フレックスボックス)と呼ばれるレイアウトモードを使用することができます。

フレックスボックス css display:flexの説明
 

シンプルな使い方は下記の通り。通常縦並びになる要素ですが、親要素をdisplay:flexを設定して(フレックスコンテナにして)、子要素を横並びにすることができます。


 

フレックスコンテナ(親要素)に設定できる項目は以下の通りです。

項目 意味
display:flex 【最重要(必須)】 フレックスコンテナの指定
justify-content 【重要】 (主軸に対して)子要素同士をどのような間隔で並べるかを指定するプロパティ
flex-wrap 【重要】 子要素(フレックスアイテム)を一行に並べるか、複数行に並べるかを指定するプロパティ
flex-direction 【重要】 子要素(フレックスアイテム)をどの方向に並べていくかを指定するプロパティ
align-items flex-directionで並べる際に、交差軸に対して子要素同士をどのような間隔で並べるかを指定するプロパティ

 

flex系のプロパティはたくさんありますが、特によく使う【重要】と記載しているプロパティをまず覚えておきましょう。

 

フレックスアイテム(子要素)には下記のプロパティが設定できます。子要素をどのようなレイアウトにするか指定できるプロパティですが、必要ない場合は設定しなくても構いません。

項目 意味
order フレックスアイテムの並べる順番をどうするか指定するプロパティ
flex-grow フレックスアイテムを他の要素と比べてどのくらい伸ばすか指定するプロパティ
flex-shrink フレックスアイテムを他の要素と比べてどのくらい縮めるか指定するプロパティ
flex-basis flex-basisはwidthのように幅を指定するプロパティ。flex-basisとwidthの両方が設定されている場合は、flex-basisが優先されます。初期値はauto。
flex flex-grow、flex-shrink、flex-basisを1つにまとめて記載できるプロパティ

 

(補足)Webブラウザの互換性について

display:flexは2023年時点でほぼ全てのブラウザに対応していますので、安心して利用できます。

2023年1月時点のdisplay:flexのwebブラウザ互換性
https://caniuse.com/より引用 2023年1月時点

なお、数年前に作ったサイトの場合は、古いブラウザ対応を明示的にするために、ベンタープレフィックス(-webkit-xxx など)を付けている場合もあります。

display:-webkit-flex;
display:flex;

 



フレックスコンテナ(親要素)に設定できるflex系プロパティ

まずは、フレックスコンテナ(親要素)に設定できるflex系のプロパティを説明していきます。

display:flexを適用
 

項目 意味
display:flex 【最重要(必須)】 フレックスコンテナの指定
justify-content 【重要】 (主軸に対して)子要素同士をどのような間隔で並べるかを指定するプロパティ
flex-wrap 【重要】 子要素(フレックスアイテム)を一行に並べるか、複数行に並べるかを指定するプロパティ
flex-direction 【重要】 子要素(フレックスアイテム)をどの方向に並べていくかを指定するプロパティ
align-items flex-directionで並べる際に、交差軸に対して子要素同士をどのような間隔で並べるかを指定するプロパティ

 

フレックスボックスの基本設定 display:flex

フレックスボックスを利用するためには、flexboxを利用する親要素に、display:flexを追加します。これにより、親要素がflexコンテナとなり、子要素がflexアイテムとなります。

■表示例 親要素にdisplay:flexを指定


 

■上記のソースコード

<html lang="ja">
<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>flexbox</title>
  <style>
     *{
       box-sizing: border-box;
     }
    #flexbox{
      display:flex;
      background:#ddd;
      width: 100%;
      height:auto;
      padding:10px;
    }
    .box-item{
      background:orange;
      text-align: center;
      padding:15px 40px;
      border:5px solid #ddd;
    }    
  </style>
</head>
<body>
  <div id="flexbox">
    <div class="box-item">1</div>
    <div class="box-item">2</div>
    <div class="box-item">3</div>
    <div class="box-item">4</div>
    <div class="box-item">5</div>             
  </div>
</body>
</html>

 
なお、孫要素(フレックスアイテム内にある要素)はflexで横並び(フレックスアイテム)になるわけではない点に注意。通常通りの配置になる点も覚えておきましょう。
孫要素にはflexの影響はない
 

フレックスアイテムの配置設定 justify-content

justify-contentというプロパティを使用すると、flex-directionで指定したフレックスコンテナの方向に沿って、フレックスアイテムをどのように配置するかを設定できます。
 

項目 内容
justify-content:flex-start 主軸の始点に配置します(デフォルト)
justify-content:flex-end 主軸の終点に配置します
justify-content:center 主軸の中央に配置します
justify-content:space-between 両端から均等に配置します
justify-content:space-around 主軸に対し均等間隔に配置します

 
 

以下は、display:flexと合わせて、justify-contentを設定した例です。

justify-content:flex-start(初期値)

display:flexを適用

<html lang="ja">
<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>flexbox</title>
  <style>
     *{
       box-sizing: border-box;
     }
    #flexbox{
      display:flex; 
      justify-content:flex-start;
      background:#ddd;
      width: 100%;
      height:auto;
      padding:10px;
    }
    .box-item{
      background:orange;
      text-align: center;
      padding:15px 40px;
      border:5px solid #ddd;
    }    
  </style>
</head>
<body>
  <div id="flexbox">
    <div class="box-item">1</div>
    <div class="box-item">2</div>
    <div class="box-item">3</div>
    <div class="box-item">4</div>
    <div class="box-item">5</div>             
  </div>
</body>
</html>

 

justify-content:flex-end

justify-content:flex-end

    #flexbox{
      display:flex;
      justify-content:flex-end;
      background:#ddd;
      width: 100%;
      height:auto;
      padding:10px;
    }

 

justify-content:center

justify-content:center

    #flexbox{
      display:flex;
      justify-content:center;
      background:#ddd;
      width: 100%;
      height:auto;
      padding:10px;
    }

 

justify-content:space-between

justify-content:space-between

    #flexbox{
      display:flex;
      justify-content:space-between;
      background:#ddd;
      width: 100%;
      height:auto;
      padding:10px;
    }

 

justify-content:space-around

justify-content:space-around

    #flexbox{
      display:flex;
      justify-content:space-around;
      background:#ddd;
      width: 100%;
      height:auto;
      padding:10px;
    }

 

 

なお、後述のflex-directionをcolumnに設定している場合は、垂直方向の配置を制御することになります。


 

フレックスアイテムを一行に収めるか複数行にするか flex-wrap

flex-wrapプロパティは、フレックスアイテムを一行(一列)に収めるか、複数行を許可するかを指定するプロパティです。
 

floatなどのプロパティーと違いとして、フレックスアイテムが親要素の幅を超えても、超えた分が下の行に落ちず必ず一行内に収まるようになっています(縮まったりはみ出したりします。)。親要素の幅を超える時に複数行にするかしないかの設定がflex-wrapです。
 

項目 意味
flex-wrap:nowrap(初期値) フレックスアイテムが一行に収まらない時でも1行に収める。
※収まらない場合は、フレックスアイテムにwidthを設定しても効かなかったりはみ出したりする
flex-wrap:wrap フレックスアイテムが一行に収まらない時に複数行にする
flex-wrap:wrap-reverse フレックスアイテムが一行に収まらない時に複数行にする(順番を逆にする)

 

■flex-wrap:wrapを指定していない場合、子要素にwidth:50%を設定しても縮んで一行に収まります。
flex-wrap:nowrap
 

■flex-wrap:wrapを指定すると50%が効いて複数行になります。
flex-wrap:wrap
 

■上記のソースコード

<html lang="ja">
<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>flexbox</title>
  <style>
     *{
       box-sizing: border-box;
     }
    #flexbox{
      display:flex; 
      flex-wrap: wrap;
      background:#ddd;
      width: 100%;
      height:auto;
      padding:10px;
    }
    .box-item{
      width: 50%;
      background:orange;
      text-align: center;
      padding:15px 40px;
      border:5px solid #ddd;
    }    
  </style>
</head>
<body>
  <div id="flexbox">
    <div class="box-item">1</div>
    <div class="box-item">2</div>
    <div class="box-item">3</div>
    <div class="box-item">4</div>
    <div class="box-item">5</div>             
  </div>
</body>
</html>

 

■ただし、フレックスアイテムの合計の横幅が100%に収まる場合はwidthが効きます。
flex-item widthの設定
 

フレックスアイテムの方向設定 flex-direction

flex-directionプロパティは、フレックスコンテナの方向(主軸)を指定するプロパティです。フレックスアイテム(子要素)はこの主軸の方向に沿って配置されます。
 

■flex:direction 主軸の向きを決定する(横方向)
flex-direction:row、row-reverse 水平方向
 

■flex:direction:column (column-reverse)の場合は垂直方向に並びます。
flex
 

初期値は、flex-direction:rowです。子要素が左から右へ順番に配置されます。初期値なので省略することが多いです。
display:flexを適用
 

項目 意味
flex-direction:row (初期値) 左から右に配置(初期値)
flex-direction:row-reverse 右から左に配置
flex-direction:column 上から右に配置
flex-direction:column-reverse 下から上に配置

 

表示例 flex-direction:row-revese(右から左へ)

flex-direction:row-reverse

■上記(flex-direction:row-revese)のソースコード

<html lang="ja">
<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>flexbox</title>
  <style>
     *{
       box-sizing: border-box;
     }
    #flexbox{
      display:flex; 
      flex-direction:row-reverse;
      background:#ddd;
      width: 100%;
      height:auto;
      padding:10px;
    }
    .box-item{
      background:orange;
      text-align: center;
      padding:15px 40px;
      border:5px solid #ddd;
    }    
  </style>
</head>
<body>
  <div id="flexbox">
    <div class="box-item">1</div>
    <div class="box-item">2</div>
    <div class="box-item">3</div>
    <div class="box-item">4</div>
    <div class="box-item">5</div>             
  </div>
</body>
</html>

 

flex-direction:column(上から下へ)

flex-direction:column

    #flexbox{
      display:flex;
      flex-direction:column;
      background:#ddd;
      width: 100%;
      height:auto;
      padding:10px;
    }

 

 

flex-direction:column-reverse(下から上へ)

flex-direction:column-reverse

    #flexbox{
      display:flex;
      flex-direction:column-reverse;
      background:#ddd;
      width: 100%;
      height:auto;
      padding:10px;
    }

 

フレックスアイテムの交差軸の配置設定 align-items

flexboxは2つの軸を持っています。flex-directionで設定した向きが主軸で、主軸に対して垂直な軸を交差軸といいます。
 

align-itemsプロパティを利用すると、flexコンテナの交差軸に沿って、flexアイテムをどのように配置するかを設定できます。
 

以下は、主軸が水平の場合の、主軸と交差軸です。
Bootstrap4 flexbox flex-rowの場合 主軸と交差軸
 

align-itemに設定できる項目は以下の通り。

項目 意味
align-items:stretch 交差軸の始点から終点まで伸縮する(初期値) ※heightを設定していない場合
align-items:flex-start 交差軸の始点に配置する
align-items:flex-end 交差軸の終点に配置する
align-items:center 交差軸の中央に配置する
align-items:space-baseline 交差軸のベースラインに配置する

 
 

■主軸が水平方向(flex-direction:row)の場合、aligh-itemsは、垂直方向の交差軸に対して配置を制御します。


 

なお、主軸が垂直方向(flex-direction:column)の場合、flex-alignsは水平方向の交差軸に対して配置を制御します。
Bootstrap 4 flexbox flex-rowの場合 主軸と交差軸
 
 

フレックスアイテム(子要素)に設定できるflex系プロパティ

ここからは、フレックスアイテム(子要素)に設定できるflex系プロパティをご紹介していきます。
 

項目 意味
order フレックスアイテムの並べる順番をどうするか指定するプロパティ
flex-grow フレックスアイテムを他の要素と比べてどのくらい伸ばすか指定するプロパティ
flex-shrink フレックスアイテムを他の要素と比べてどのくらい縮めるか指定するプロパティ
flex-basis flex-basisはwidthのように幅を指定するプロパティ。flex-basisとwidthの両方が設定されている場合は、flex-basisが優先されます。初期値はauto。
align-self flex-directionで並べる際に、交差軸に対して子要素同士をどのような間隔で並べるかを指定するプロパティ

 

順番を制御 Order

orderプロパティを利用すると、フレックスアイテム(子要素)の順番を制御することができます。
 

■表示例
flex orderの例
 

■上記のソースコード

<html lang="ja">
<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>flexbox</title>
  <style>
     *{
       box-sizing: border-box;
     }
    #flexbox{
      display:flex; 
      background:#ddd;
      width: 100%;
      padding:10px;
    } 
    .box-item{
      background:orange;
      text-align: center;
      padding:15px 40px;
      border:5px solid #ddd;
    }    
  </style>
</head>
<body>
  <div id="flexbox">
    <div class="box-item" style="order:3">1</div>
    <div class="box-item" style="order:4">2</div>
    <div class="box-item" style="order:5">3</div>
    <div class="box-item" style="order:1">4</div>
    <div class="box-item" style="order:2">5</div>               
  </div>
</body>
</html>

 

フレックスアイテムの幅の指定flex-basis

フレックスアイテムの幅の指定をするプロパティがflex-basisです。
 

flex-basis初期値はautoです。flex-basisは、widthと同じ意味でflex-basisとwidthの両方が設定されている場合は、flex-basisが優先されます。
 

■flex-basisの表示例

 

<html lang="ja">
<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>flexbox</title>
  <style>
     *{
       box-sizing: border-box;
     }
    #flexbox{
      display:flex; 
      background:#ddd;
      width: 100%;
      padding:10px;
    } 
    .box-item{
      background:orange;
      text-align: center;
      padding:15px 40px;
      border:5px solid #ddd;
    }    
  </style>
</head>
<body>
  <div id="flexbox">
    <div class="box-item" style="flex-basis:30%;">1</div>
    <div class="box-item" style="flex-basis:30%;">2</div>
    <div class="box-item" style="flex-basis:150px;">3</div>
    <div class="box-item">4</div>
    <div class="box-item">5</div>               
  </div>
</body>
</html>

 

フレックスアイテムをどのくらい伸ばすか flex-grow

フレックスアイテムを他の要素と比べてどのくらい伸ばすか指定できるプロパティがflex-growです。
 

■flex:growのサンプル例
flex:grow
 

■上記のソースコード

  <div id="flexbox">
    <div class="box-item">1</div>
    <div class="box-item" style="flex-grow:0">2</div>
    <div class="box-item" style="flex-grow: 1;">3</div>
    <div class="box-item" style="flex-grow: 2;">4</div>
    <div class="box-item" style="flex-grow: 3;">5</div>               
  </div>

 

フレックスアイテムをどのくらい縮めるか flex-shrink

フレックスアイテムを他の要素と比べてどのくらい縮めるか指定できるプロパティがflex-growです。数字を設定でき、初期値(伸縮なし)は「0」です。
 

flex-shrink
 

 

まとめ

まとめです。今回は、フレックスボックス(フレキシブルボックス)で要素のレイアウトを調整する方法を紹介しました。

フレックスボックスは、display:flexで実現でき従来のfloatよりも柔軟なレイアウトを組むことができます。

フレックスボックス css display:flexの説明
 


 

他にも、displayではインライン要素やブロックレベル要素への変更、グリッドレイアウト(display:grid)などいろいろな使い方があるので余力のある方はぜひ覚えておきましょう。

なお、これからサーバーやドメインを契約してホームページを作りたいという方は「【総まとめ】個人ホームページの作り方・Webサイト自作方法」をご参考ください。

今回は以上になります。最後までご覧頂き、ありがとうございました。
 

 

「業者に任せたけど、更新ができない」「本で独学は時間がかかりすぎる・・」そんなお悩みの方も多いのではないでしょうか。

個別指導形式のスクールでは、自分の知りたいことをピンポイントで学習・達成でき、自分で更新もできるというメリットもあります。

教室の無料事前相談もしておりますので、まずはお気軽にご登録ください。

詳細はこちら

YouTubeチャンネル開設しました!

WEBST8 YouTube Channel 開設
最大月間50万PVの当ブログをベースに、Youtube動画配信にてWordPress、ホームページ作成、ブログのことについてお役立ち情報を随時配信していきます。

ご興味ある方はぜひチャンネル登録をしていただけますと幸いです。



検索して記事を見つける

探したいキーワードを入力・検索して記事を見つけたい方はこちら

-CSS