ホームページ >ウェブフロントエンド >CSSチュートリアル >幅が異なる場合にSVGをDiv内で中央に配置する方法は?

幅が異なる場合にSVGをDiv内で中央に配置する方法は?

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-02 02:18:30956ブラウズ

How to Center an SVG Within a Div When the Widths Differ?

Div 内での SVG の位置合わせ

div 内で SVG を中央に配置することは、特に div と SVG の幅が異なる場合に問題が生じる可能性があります。質問で示された問題を調査し、考えられる解決策を検討してみましょう。

問題ステートメント

ユーザーは、margin-left: auto と margin-right: auto を使用して、SVG を div 内の中央に配置しようとします。ただし、SVG は、margin-left が 0 に設定されているかのように左揃えのままになります。

解決策

この問題は、デフォルトで SVG がインライン コンテンツであるために発生します。ブロックレベルにするには、display: block を明示的に指定する必要があります。これを実行すると、margin: auto が意図したとおりに機能し、SVG が div 内の中央に配置されます。

<code class="CSS">svg {
  display: block;
  margin: auto;
}</code>

代替アプローチ

  1. Text-align: SVG の表示を変更する代わりに、text-align: center を使用して親要素内で SVG を位置合わせできます。このアプローチでは、SVG はインラインに保たれますが、親の中央に配置されます。
  2. フレックス/グリッド レイアウト: フレックス レイアウトまたはグリッド レイアウトは、別の代替手段を提供します。親要素をフレックス コンテナまたはグリッド コンテナとして設定すると、align-items または justify-items プロパティを使用して SVG を中央に配置できます。

要約すると、SVG がブロックとして表示されるようにする必要があります。 level 要素 (表示: ブロック) を使用すると、中央揃えに margin: auto を使用できます。あるいは、text-align: center または flex/grid レイアウトを使用して、親要素内で SVG を効果的に配置することもできます。

以上が幅が異なる場合にSVGをDiv内で中央に配置する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。