ホームページ > ウェブフロントエンド > CSSチュートリアル > Flex アイテムがマージンとボックス サイズを無視するのはなぜですか: ボーダー ボックスの問題ですか?

Flex アイテムがマージンとボックス サイズを無視するのはなぜですか: ボーダー ボックスの問題ですか?

Susan Sarandon
リリース: 2024-11-03 18:07:29
オリジナル
728 人が閲覧しました

Why Are Flex Items Ignoring Margins and Box-Sizing: A border-box Problem?

マージンとボックス サイズを考慮しないフレックス アイテム: border-box

CSS では、ボックス サイズ プロパティによって要素の幅と高さがどのように計算されるかが決まります。パディングまたはボーダー。 border-box に設定すると、要素の寸法にはパディングとボーダーの両方が含まれます。ただし、ボックス サイズ プロパティに関係なく、マージンは常に個別に計算されます。

フレックスボックスを使用する場合、マージン: 10px で flex を 1 1 33.33% に設定すると、予期しない動作が発生します。 Flexbox は通常、使用可能なスペースをアイテム間で均等に分配しますが、このシナリオではマージンは考慮されません。その結果、期待される 1 行あたり 3 つの項目が達成されません。

この問題を解決するには、flex-basis プロパティを調整できます。示されている例では、flex-basis は 26% に設定されています。これは、各項目の希望の幅からマージンを差し引いた値です。マージンがフレックス ベースに考慮されていないことを確認することで、Flexbox はアイテムを正しく配置し、意図したとおりにラップします。

<code class="css">.horizontal-layout {
  display: flex;
  width: 400px;
}

header > span { 
  flex: 1 0 26%;                    /* ADJUSTED */
  margin: 10px;
}

header#with-border-padding {
  flex-wrap: wrap;
}

header#with-border-padding>span {
  flex: 1 0 26%;                   /* ADJUSTED */
}</code>
ログイン後にコピー

以上がFlex アイテムがマージンとボックス サイズを無視するのはなぜですか: ボーダー ボックスの問題ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート