質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

346閲覧

CSSでボックスを画面の左右中央に縦に並べたい

narimi

総合スコア18

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2023/03/11 02:34

編集2023/03/12 09:56

実現したいこと

divタグのクラスに対してCSSでボックスを作成し,複数生成したそれらを画面の左右中央に縦に並べたいです

前提

画面背景をposition:abusolute,width:100%で指定し,
それらに対して新たに二つのボックスをposition:relativeで配置したいです.

先の開発では,それらの作成したboxに対してposition:abusoluteで要素を配置していこうと思っています.

発生している問題・エラーメッセージ

問題としては,boxが横並びになってしまうという形です.
イメージ説明}

該当のソースコード

HTML

1 <div id="start-screen" className="background"> 2 <div id="title_box"> 3 <p id="yokoso">ようこそ</p> 4 </div> 5 <div id="ctachfrase_box"> 6 <p id="あ">あ</p> 7 </div> 8 </div>

CSS

1#start-screen { 2 position: absolute; 3 width: 100%; 4 height: 7200px; 5 display: flex; 6 justify-content: center; 7 text-align: center; 8 padding: 276px; 9 background: #FFDDDD; 10} 11#title_box { 12 position: relative; 13 min-width: 804px; 14 height: 658px; 15 left: 0px; 16 top: 0px; 17 background: #F5F5F5; 18 box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25); 19 border-radius: 30px; 20} 21#ctachfrase_box { 22 position: relative; 23 width: 180px; 24 height: 200px; 25 left: 0px; 26 top: 700px; 27 background: #F5F500; 28 box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25); 29 border-radius: 30px;

試したこと

flex-direction: column;
等の記述を加えると縦に並びはするのですが,そうするとようこその方(tittle_box)のwidthが二つのboxを加算したものになってしまい,非常に横長のboxが二つ出来上がることになります.
イメージ説明

align-items: flex-center;
を書くとimg画像が縦に並ぶといった旨の記事はみましたが,何も変わりませんでした.

補足情報(FW/ツールのバージョンなど)

かなり初歩的な質問で申し訳ありません.
また,実現したい内容が全く別の方法で可能なのであればそれでもかまいません.

一応環境としてはreactを用いたjavascript内で書いています.

その他,補足内容等が必要でしたら,コメントしていただけると幸いです.

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Flexboxでアイテムを『画面の左右中央に縦に並べたい』ということなら、下記になります。

css

1 display: flex; 2 flex-direction: column; /* 縦方向に並べる */ 3 align-items: center; /* 交差軸(columnの場合は水平方向)の中央 */

最終的な理想のレイアウトが不明確ですが、とりありずサンプルコードを提示しておきますのでご参考に。

css

1#start-screen { 2 width: 100%; 3 height: 7200px; 4 display: flex; 5 flex-direction: column; 6 align-items: center; 7 text-align: center; 8 padding: 276px; 9 background: #FFDDDD; 10 box-sizing: border-box; 11} 12#title_box { 13 min-width: 804px; 14 height: 658px; 15 background: #F5F5F5; 16 box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25); 17 border-radius: 30px; 18} 19#ctachfrase_box { 20 width: 180px; 21 height: 200px; 22 margin-top: 42px; 23 background: #F5F500; 24 box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25); 25 border-radius: 30px; 26}

投稿2023/03/11 04:47

hatena19

総合スコア33620

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

narimi

2023/03/12 00:56

出来ました,,,! ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問