Flexboxはご存知でしょうか。

Fexboxはサイズが動的なデータの場合でも、コンテナー内のより効率的なレイアウト、配置、およびアイテムとスペースの分配の提供を目的としています。Flexboxは柔軟性があり、フロートやpositionを使用せずにレスポンシブレイアウトを簡単に設計できます。

  • 水平方向の位置のあるテキスト、コンテンツのブロックと別のブロックを中央に整列させる必要がある
  • 中央に整列のためCSSトリックを利用するが、全画面または動的データが表示されない状態になる
  • サードパーティのライブラリを利用せずに、レスポンシブインターフェースの設計が大変

など、FexboxならPhotoshopから画像を書き出す際に起こりがちな問題を解決することができますよ。

  • IT人材が不足している事業者様
  • floatを使用したレイアウトを行っていた方
  • Flexbox について詳しく知りたい方

これらに当てはまる方におすすめの記事となっています。これを読めばFlexboxの使い方や概要を知ることができます。

Flexbox CSSとは?

これはCSS3のモジュールの一つであり、あらゆるデバイスに表示され、柔軟に直感的なレイアウトを作成できるよう、内部要素を自動的にスケーリングするWebレイアウトモデルです。

Flexboxは、サイズや距離も含めて、コンテナーのアイテムを均等に分散する方法をコンテナーに決定させます。

Flexboxは多くのサイトにて利用されています( Bootstrap3のfloatに代わり、Bootstrap4もFlexboxを利用してグリッドシステムを構築しています)。

Flexboxは、純粋なCSSの問題を取り除くのに役に立つことが見込まれています。ただし、この新しいモデルを慣れるのは簡単なことではありません。

Flexboxの構造

Flexboxについて詳しく説明する前に、Flexboxの構造を簡単に確認する必要があります。 以下にはFlexboxの構造図です。

Flexbox構造には、コンテナーとアイテムの2つのコンポーネントがあります。

コンテナー

内部の要素を囲む大きなコンポーネントです

アイテム

コンテナーの子要素はアイテムと呼ばれます。

アイテムでは、コンテナーで使用する列の数を設定したり、表示順序を設定したりできます。

Flexboxの概念

Flexbox構造の中では、以下にいくつか概念を理解する必要があります。

Main start と Main end

Flexboxを設定する際に、コンテナーの開始点はメインスタートで、終点はメインエンドと呼ばれます。

つまり、内部のアイテムはメインスタートからメインエンドまで表示されます(またはメインエンドまで表示できます)。

そして、その垂直寸法のクロススタート、クロスエンドは同じ意味ですが、常にメインスタート、メインエンドに垂直となります。

Main axis

Main axisは、アイテムの表示方法を制御する主軸です。

Main size

Main sizeはmain axisに基づくアイテムのサイズです。

Cross axis

Main axisに似ているが、ain axisに垂直です。

Cross size

cross axisに基づくアイテムのサイズです。

Flexboxコンテナーと属性

Flexboxコンテナーは最も外側の要素であり、内部に子アイテム(Flex items)を含みます。

この要素では、プロパティdisplay:flex:、またはdisplay:inline-flexを設定する必要となります。

そこでは、下記のプロパティを使用してFlex itemsのレイアウトを構成します。

flex-direction

row | row-reverse | column | column-reverse;main axisを設定します。デフォルトがrowであり、ほとんどの場合にはrowにします(フレックスアイテムが水平行にあります)。

flex-wrap

nowrap | wrap | wrap-reverse; フレックスアイテムの幅を設定する時、この属性として、コンテナーの幅を超えた場合にフレックスアイテムを改行にするかどうかを指定します。

デフォルトは改行にします(nowrap)

Flex-flow  [flex-direction] [flex-wrap]

Flex-flow は、上記の2つの属性を組み合わせたものです。

justify-content

flex-start | flex-end | center | space-between | space-around | space-evenly | start | end | left | right … + safe | unsafe; main axis(主軸)に従ってフレックスアイテムの配置として設定されます。

align-items

stretch | flex-start | flex-end | center | baseline | first baseline | last baseline | start | end | self-start | self-end + … safe | unsafe;cross axis(交差軸)に従ってフレックスアイテムの配置として設定されます。

align-content

flex-start | flex-end | center | space-between | space-around | space-evenly | stretch | start | end | baseline | first baseline | last baseline + … safe | unsafe; cross axis(交差軸)に従ってフレックスアイテムの配置として設定されます。

Flex itemsと属性

親タグがFlexboxコンテナであるエレメントは、Flex itemsとして扱われます。

Flex itemsには、コンテナー内の独自のサイズと位置をカスタマイズできるように下記のプロパティがあります。

  • flex-grow: number; /* default 0 */コンテナー内でのアイテムスペースを設定します。
  • flex-shrink: number; /* default 1 */ コンテナーの収縮に従ってアイテムの縮小係数を設定します
  • flex-basis: number| auto; /* default auto */ アイテムのサイズが設定されます。
  • flex: none | [ <‘flex-grow’> <‘flex-shrink’>? || <‘flex-basis’> ] 上記の3つの属性の省略形です。
  • order: number; /* default is 0 */ コンテナー内のアイテムの位置が設定されます。
  • align-self: auto | flex-start | flex-end | center | baseline | stretch;cross axisに従ってアイテムの配置が設定されます。この属性はalign-itemsをオーバーライドにします。

結論

CSSのFlexboxは、floatを使用した通常のレイアウトを変える非常に便利なページレイアウトカスタマイズの1つであると言えます。

floatの不要な使用を最小限に抑えるため、サイトの小さな要素のレイアウトに適しています。

Mozilla Firefoxから推奨設定によると、Flexboxを使用して小さな領域(サイトのフレームなど)にレイアウトを設定します。

より大きなスケール(サイトの列など)にレイアウトを設定する際には、CSS Grid LayoutはCSSの中ですでに一番強力なイアウトシステムと言えます。これは2次元システムです。

つまり、一方向のシステムであるFlexboxとは異なり、列と行の両方を処理できます。

Flexboxの概要を紹介しました。 Flexboxは使いやすいと言えますが、習得するには多くの練習が必要です。

=>  Flexboxを学ぶための楽しいゲームを皆さんに紹介します

dehaでは、5年ほど前から、ベトナムオフショア開発を行っています。

ベトナムでオフショア開発を行う際の費用や、エンジニアの質を知りたい方は、無料で見積もりいたしますので、お気軽にお問い合わせください。

お問い合わせはこちらから

Mai Tran

Recent Posts

構造変化に直面するオフショア開発:「量」の補完から「AI Native」への転換期

オフショア開発は従来の「量」の補完から、しかし、生成AIの急速な進化によってその前提が大きく変わろうとしています。 今後は「どれだけ高い生産性を実現できるか」が重要です。 この記事ではそのようなオフショア開発のあり方の変化について見ていきます。 オフショア開発に興味がある方 社内のIT人材が不足している方 AIを使った開発に興味がある方 これらに当てはまる方におすすめの記事となっています。これを読めばオフショア開発の変化についてわかるのはもちろん、AI Nativeについても丸わかりですよ。 オフショア開発の前提が変わり始めている オフショア開発はここ20年ほど、日本のIT業界を支える重要な仕組みとして成長してきました。 少子高齢化による人材不足や開発コストの上昇を背景に、多くの企業が中国、インド、ベトナム、ミャンマーなどの海外人材を活用してきました。 従来のオフショア開発の価値は非常に分かりやすいものでした。日本国内で不足するエンジニアリソースを海外で補うというものです。 例えば、日本で10人必要なプロジェクトがあれば、その一部を海外チームに委託することで開発スピードを維持しながらコストを抑えることができました。 このモデルは長い間機能してきました。しかし、生成AIの急速な進化によって、その前提が大きく変わろうとしています。 かつてソフトウェア開発では、「開発量を増やすためには人を増やす必要がある」という考え方が一般的でした。…

20 hours ago

生成AI時代における「2030年に79万人IT人材不足」の再定義と構造変化

近年、日本のIT業界では「2030年に最大79万人のIT人材が不足する」という予測が繰り返し語られています。 この数字は、日本社会のDX推進や企業のシステム開発を支える人材の不足を警告する象徴的な指標として広く認知されています。 しかし、2022年末以降の生成AIの急速な発展により、この予測の前提条件は大きく変化しています。 かつては人間が手作業で行っていたプログラミング、設計書作成、テストケース生成、ドキュメント作成、データ分析などの業務が、AIによって大幅に自動化され始めているためです。 その結果、「79万人不足」という予測を単純に受け入れるのではなく、「どのような人材が不足し、どのような人材の需要が減少するのか」という質的な観点から再検討する必要が生じています。 この記事では、生成AI時代におけるIT人材不足の構造変化を分析し、2030年に向けて求められる人材像について考察をしていきます。 生成AI時代が気になる方 IT業界の方 社内のIT人材が不足している方 これらに当てはまる方におすすめの記事となっています。これを読めば「2030年79万人IT人材不足」問題について、新しい見解とその対策がわかりますよ。 (more…)

2 weeks ago

AIレガシーマイグレーション|従来の課題をDXへ導くDEHAの解決策

長年運用されてきた基幹システムは、企業活動を支える重要な存在である一方で、技術的負債の蓄積、保守人材不足、クラウド対応の遅れ、ブラックボックス化など、さまざまな問題を引き起こしています。 従来のマイグレーションでは、既存システムの解析からコード変換、データ移行、テスト、カットオーバーまで、多くの工程を人手に依存していました。 こうした背景の中、注目を集めているのが「AIレガシーマイグレーション」です。 この記事ではAIレガシーマイグレーションについて、どんな特徴があるのかやその強みに着目をしていきたいと思います。 AIレガシーマイグレーションが気になる方 製造業の方 DXをすすめたい企業の方 これらに当てはまる方におすすめの記事となっています。これを読めばAIレガシーマイグレーションがどう言ったものかがわかるのはもちろん、DEHAのAIレガシーマイグレーションについてもわかりますよ。 (more…)

4 weeks ago

AI Nativeとは?企業が導入すべき理由と開発現場にもたらす変革

近年、企業のIT戦略やシステム開発において「AI Native(AIネイティブ)」という言葉が急速に注目を集めています。 この記事ではそんなAI Nativeについて、その概要やメリットなどを紹介していきます。 AI Nativeが気になる方 システム開発をお考えの方 社内にIT人材が不足している方 これらに当てはまる方におすすめの記事となっています。これを読めばAI Nativeが何かがわかるのはもちろん、導入するべき理由が丸わかりですよ。 (more…)

4 weeks ago

【全12種類】IFS Cloudの主要モジュールを徹底解説

IFS Cloudは、スウェーデン発のグローバルERPパッケージであり、ERP、EAM(設備資産管理)、SM(サービス管理)を統合的に提供する統合プラットフォームです。 本日はそんなIFS Cloudについて主要モジュールを解説します。 IFS Cloudに興味がある方 ERPをお探しの方 製造業の方 これらに当てはまる方におすすめの記事となっています。これを読めばIFS Cloudについてわかるのはもちろん、IFS Cloudの強みまで丸わかりですよ。 (more…)

1 month ago

【2026年最新】IFS CloudとOracle Cloud ERPの違いを徹底比較

企業のDX推進が本格化する中で、ERP(基幹業務システム)の役割は単なる業務管理ツールから、経営基盤そのものへと変化しています。 その中で、世界的に注目されているクラウドERPが IFS とOracle Cloud ERPです。 どちらも世界トップクラスのERPとして高く評価されていますが、実際には設計思想や得意分野が大きく異なります。 IFS Cloudは「現場・設備・サービス」を重視したERPであり、製造業やインフラ産業との相性が非常に高いことで知られています。 一方のOracle Cloud ERPは、「財務・経営統制・グローバル管理」を重視したERPであり、多国籍企業や大企業における経営管理基盤として強みを発揮しています。 そのため、「どちらが優れているか」という単純な比較ではなく、「自社の業務や経営戦略にどちらが適しているか」を見極めることが重要になります。 この記事では、IFS CloudとOracle…

1 month ago