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

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

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

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

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

Q&A

2回答

661閲覧

表示される要素の幅や表示位置について

study_111

総合スコア82

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

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

0グッド

0クリップ

投稿2021/08/30 02:50

現在、HTML,CSSを使用したUIの構築を行なっているのですが、表示がうまくいかなかった為、ご助言頂きたく質問させて貰いました。
コードの方は以下になります。

html

1<div class="info"> 2 <p>教科データです</p> 3 <p class="name">testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest</p> 4 <div class="item"> 5 <div> 6 <p>テスト</p> 7 <p>項目1:数学</p> 8 <p>項目2:英語</p> 9 </div> 10 </div> 11</div>

css

1.info { 2 display: flex; 3 flex-flow: row nowrap; 4 justify-content: space-between; 5 align-items: stretch; 6 background-color: #F5F5F5; 7 border: solid 1px #C4C4C4; 8} 9 10.name, 11.item { 12 display: flex; 13 flex-flow: row nowrap; 14 justify-content: center; 15 align-items: center; 16} 17 18.name { 19 flex-grow: 1; 20 flex-shrink: 1; 21 min-width: calc(50% + 1px); 22 max-width: calc(50% + 1px); 23 margin: 0; 24 padding: 0 1px 0 0; 25 background-image: linear-gradient(#C4C4C4, #C4C4C4); 26 background-repeat: no-repeat; 27 background-size: 1px 80%; 28 background-position: right center; 29} 30 31.item { 32 flex-grow: 1; 33 flex-shrink: 1; 34}

こちら、JSFiddleにて動作確認可能な状態となっております為、一度ご確認頂けましたら幸いです。
問題点ですが、現状、htmlのnameクラスに設定した文字列が真ん中の縦線を突っ切って右側に大きく入り込んでしまっています。
イメージ説明

また、日本語の文字列を<p class="name">テストテストテストテストテストテスト</p>こちらのように設定した場合に、左端ではなく真ん中の場所から表示されるようになってしまっています。
イメージ説明

こちらの2点の解決方法が分からない為、どなたかご助言頂けましたら幸いです

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

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

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

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

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

guest

回答2

0

htmlのnameクラスに設定した文字列が真ん中の縦線を突っ切って右側に大きく入り込んでしまっています。

→.nameにword-break: break-all;を追加

左端ではなく真ん中の場所から表示されるようになってしまっています。

→infoの中がflexになっているので、教科データとテストのpタグをdivタグで囲ってください。
widthが崩れるので、囲ったdivにwidth設定、.nameのmax-widthを外すなど適宜調整してください。

HTML

1<div class="info"> 2 <div id="hoge"> 3     <p>教科データです</p> 4    <p class="name">test</p> 5 </div> 6

投稿2021/08/30 03:02

meli

総合スコア312

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

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

study_111

2021/08/30 03:23

ご回答ありがとうございます。 > htmlのnameクラスに設定した文字列が真ん中の縦線を突っ切って右側に大きく入り込んでしまっています。 こちらに関しましては、 ward-breakにbreak-allプロパティを追加することで解決することが出来ました。 >教科データとテストのpタグをdivタグで囲ってください。 こちらdivタグで囲う形にし、widthを設定してみたのですが、元々の表示に影響が出てしまったのか少々崩れた形となってしまいました...
guest

0

右側に大きく入り込んでしまっています。

word-breakの設定で変更できます。

word-break - CSS: カスケーディングスタイルシート | MDN

左端ではなく真ん中の場所から表示されるようになってしまっています。

.nameの以下の設定が効いています。

justify-content: center;
align-items: center;

投稿2021/08/30 03:01

itagagaki

総合スコア8402

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

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

study_111

2021/08/30 03:17

ご回答ありがとうございます。 > word-breakの設定で変更できます。 こちら、break-allプロパティを設定することで、改行されるようになりました。 > .nameの以下の設定が効いています。 こちら試しに2つのプロパティを外してみたのですが、表示が崩れてしまいました。 何か解決する方法はありますでしょうか...?
itagagaki

2021/08/30 03:33

justify-content: left; にすれば左に寄ります。 align-items: center; はそれでいいのかな。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問