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

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

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

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

HTML5

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

解決済

ブログカードのレイアウトが崩れます

niconic73027793
niconic73027793

総合スコア203

CSS3

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

HTML5

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

1回答

0評価

0クリップ

148閲覧

投稿2022/05/19 09:49

編集2022/05/19 22:18

ブログカードの部分のCSSを組んでいます。

記事数が増えてもレイアウトが崩れないように、justify-content:space-between; を使わずに、
marginをとり、nth-of-type で制御しています。

» 【HTML&CSS】カード型レイアウト(モジュール)のコーディング方法 - PENGIN BLOG
リンク内容

のサイトを参考に組んでいます。

横幅を width:calc(100% / 3 - 50px / 3); のように calc で指定するとボックスが潰れてしまいます。

イメージ説明

作りたいレイアウト

作りたいレイアウトのキャプチャーURL

上記のようにしたいのですが、 何故つぶれてしまうのでしょうか?

また、デザインカンプのカードのボックス幅が200pxなのですが、
200px にするとつぶれないのですが、

イメージ説明

このように 3列2行にならず 2列 になってしまいます。

下記はコードペンのURLです。
コードペンのURL

どうすれば、3枚のカードを横並びにし、2列にできるのでしょうか?

試した事、
余計なmargin:paddingがついているか検証ツールでみましたがついていませんでした。
試しに、右に付けるmargin:25px  したにつけるmargin:25px をなくてもかわりませんでした。

<section id="blog"> <div class="container"> <div class="blog-and-facebook-box"> <div class="blog-news"> <div class="contents"> <ul class="blog-list"> <li><a href="#"> <article class="blog-list-item"> <div class="thumbnail"> </div><!-- /.thumbnail --> <div class="text-box"> </div><!-- /.text-box --> </article> </a></li> <li><a href="#"> <article class="blog-list-item"> <div class="thumbnail"> </div><!-- /.thumbnail --> <div class="text-box"> </div><!-- /.text-box --> </article> </a></li> <li><a href="#"> <article class="blog-list-item"> <div class="thumbnail"> </div><!-- /.thumbnail --> <div class="text-box"> </div><!-- /.text-box --> </article> </a></li> <li><a href="#"> <article class="blog-list-item"> <div class="thumbnail"> </div><!-- /.thumbnail --> <div class="text-box"> </div><!-- /.text-box --> </article> </a></li> <li><a href="#"> <article class="blog-list-item"> <div class="thumbnail"> </div><!-- /.thumbnail --> <div class="text-box"> </div><!-- /.text-box --> </article> </a></li> <li><a href="#"> <article class="blog-list-item"> <div class="thumbnail"> </div><!-- /.thumbnail --> <div class="text-box"> </div><!-- /.text-box --> </article> </a></li> </ul><!-- /.blog-list --> </div><!-- /.contents --> </div><!-- /.blog-news --> <div class="facebook-news"> <div class="contents"> </div><!-- /.contents --> </div><!-- /.facebook-news --> </div><!-- /.blog-and-facebook-box --> </div><!-- /.container --> </section><!-- /#blog --> ```ここに言語を入力 /* 中身のコンテンツ幅を指定するための共通クラス */ .container { max-width: 1440px; margin: 0 auto; padding: 0 10%; width: 100%; } ul li{ list-style:none; } /*------------------------------------------- blog -------------------------------------------*/ ul{ padding:0; margin:0; } ul li{ list-style:none; margin:0; padding:0; } #blog { padding:100px 0; } #blog .blog-and-facebook-box{ outline:1px solid #000; display:flex; } #blog .blog-and-facebook-box .blog-news .section-title { width:85px; } #blog .blog-and-facebook-box .facebook-news .section-title { width:165px; } #blog .blog-news{ outline:1px solid #000; width:650px; height:450px; } #blog .blog-news .contents{ margin-top:50px; outline:1px solid #000; } #blog .blog-news .contents .blog-list{ display:flex; flex-wrap:wrap; margin:0; padding:0; } #blog .blog-news .contents .blog-list .blog-list-item{ width:calc(100% / 3 - 50px / 3); height: 160px; margin-right: 25px; margin-bottom: 25px; outline:1px solid #000; } #blog .blog-news .contents .blog-list .blog-list-item :nth-of-type(3n){ margin-right:0; } #blog .facebook-news{ outline:1px solid #000; width:500px; height:450px; margin-left:50px; } #blog .facebook-news .contents{ margin-top:50px; outline:1px solid #000; }

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

recal

2022/05/19 10:07

画像ではulのpaddingがありませんが codepenではulのpaddingが付いたままです。 本当のソースコードはどうなっていますか?
niconic73027793

2022/05/19 10:47

codepenのul にpadding付いてますか? #blog { padding:100px 0; } のsection を囲っているid には付けていますが ulにはpadding 付けないです。
recal

2022/05/19 11:05 編集

あれ、そうですか。こっちの環境の影響でしょうかね。 ご自身のcodepenの画面は確認してみましたか? #blog .blog-news .contents .blog-list .blog-list-item :nth-of-type(3n){ margin-right:0; }これmargin消えてないので当たってないですね。 それとメディアクエリは使わないのでしょうか? 320pxまでこのレイアウトで行く予定ですか? flexの代わりにgridなどを利用する事も可能でしょうか?
niconic73027793

2022/05/19 11:27

コードペンだと 余白がついていたので、  ulに margin:0; padding:0;を追加しました。 確かに #blog .blog-news .contents .blog-list .blog-list-item :nth-of-type(3n){ margin-right:0; }これmargin消えてないので当たってないですね。 当たってないですね。 スマホサイズになったら、メディアクエリで3列から2列にしたいとおもっています。 flex で実現したいです。

まだ回答がついていません

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

CSS3

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

HTML5

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