webデザインについて質問です。
現在グッリドデザインを使ったレスポンシブデザインのwebサイトのデザインをしています。
コードは以下です
----html----
<div class="grid">
<ul>
<li class="grid1"></li>
<li class="grid2">b</li>
<li class="grid3">c</li>
<li class="grid4">d</li>
<li class="grid5">e</li>
</ul>
</div>
---css----
html,body,
ul,ol,li,
h1,h2,h3,h4,h5,h6,p,
form,input,div{
margin: 0;
padding: 0;
}
.grid{
width: 100%;
height: 670px;
background-color: aqua;
}
div.grid li{
display: block;
float: left;
list-style: none;
}
li.grid1{
width: 25%;
height: 670px;
background-color: beige;
}
li.grid2{
width: 48%;
height: 335px;
background-color: brown;
}
li.grid3{
width: 27%;
height: 335px;
background-color: chocolate;
}
li.grid4{
width: 27%;
height: 335px;
background-color: darkcyan;
}
li.grid5{
width: 48%;
height: 335px;
background-color: darkgray;
}
.grid ul:after{
content: "";
clear: both;
display: block;
}
こんな感じなのですが、グリッドの1つ1つに画像をbackground-imageで表示させた場合、サイトの横幅を変えたときに画像がうまく表示されません(repeat: no-repeat、size: cover;にして表示した場合、横幅を変えたときに画像の端が表示されます)
これをサイトの横幅を変えても画像の縦横の比率が変わらずに全体表示され続けるようにしたいです。
http://mosaic-theme-active.myshopify.com/
上記のサイトは横幅を変えても画像も全体表示されたままです。
私のコードではheightを指定してしまっているため、上記のサイトのようにheightが可変でサイトの横幅が変えられても画像の縦横の比率を維持できないのだとおもうのですが、どのように書けばいいかわかりません・・・。
他にも使用する画像の解像度や画像指定のプロパティなど間違っているところが色々あるとおもいますが、、、
とてもヘタクソな説明ですが、わかる方よろしくお願いしますm(_ _)m
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
No.1です。
微妙に間違えた。以下が正解です。
gridの部分のみ記載。
.grid{
width: 100%;
height:100%;
background-color: aqua;
}
div.grid li{
display: block;
float: left;
list-style: none;
}
li.grid1{
width: 25%;
height:0;
padding-bottom:100%;
background-color: beige;
}
li.grid2{
width: 48%;
height:0;
padding-bottom:50%;
background-color: brown;
}
li.grid3{
width: 27%;
height:0;
padding-bottom:50%;
background-color: chocolate;
}
li.grid4{
width: 27%;
height:0;
padding-bottom:50%;
background-color: darkcyan;
}
li.grid5{
width: 48%;
height:0;
padding-bottom:50%;
background-color: darkgray;
}
No.1
- 回答日時:
cssのgrid部分のみ記載
heightは全て削除。代わりにpadding-bottom:xx%; で調整する。
以下は例なのでxxを調整して下さい
.grid{
width: 100%;
background-color: aqua;
}
div.grid li{
display: block;
float: left;
list-style: none;
}
li.grid1{
width: 25%;
padding-bottom:103%;
background-color: beige;
}
li.grid2{
width: 48%;
padding-bottom:50%;
background-color: brown;
}
li.grid3{
width: 27%;
padding-bottom:50%;
background-color: chocolate;
}
li.grid4{
width: 27%;
padding-bottom:50%;
background-color: darkcyan;
}
li.grid5{
width: 48%;
padding-bottom:50%;
background-color: darkgray;
}
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- HTML・CSS 書籍を見つつサイト造りの練習をしているのですが、見た目が一致しません 2 2022/11/28 15:00
- HTML・CSS ヘッダーの画像にメインエリアがかぶってしまいます 1 2022/11/28 14:06
- HTML・CSS HTML & CSS 縦ボックス内の文字の左右センタリング 3 2023/03/25 04:23
- PHP style.cssのjQuery条件付きcssが機能しない 4 2022/07/17 18:27
- HTML・CSS CSS のみのタブ切り替えについて 1 2023/01/11 16:47
- HTML・CSS cssの display: flex;で横並びにならずに困ってます 1 2022/12/04 13:18
- HTML・CSS スクロールすると追従する画像のコードを書いているのですが、追従する画像の大きさの調節が上手くいきませ 2 2022/04/18 12:52
- HTML・CSS アコーディオンメニューが思うように動作しません。 1 2023/08/20 16:48
- HTML・CSS htmltとcssの連携をして画像縮小について 1 2022/11/15 20:32
- JavaScript html5に変えるとスライドショーが消えてしまった。 3 2022/03/26 19:53
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
<ul><li></li></ul>にするメリ...
-
<table>の高さ固定。情報増加時...
-
リストの数字のフォントサイズ...
-
アコーディオンメニューがかく...
-
html/cssの、navを2段にする...
-
html <li>の中の文字一部に色を...
-
番号付きリスト(<Ol><Li>・・...
-
jQuery-もっと見るボタンをスマ...
-
「olタグ」内に「hタグ要素」...
-
HTMLで組織図を作成する方法
-
【CSS】メニュー上部に固定させ...
-
ulタグやliタグの中でbrタグ...
-
li 長さ指定
-
htmlの<ol>タグで、数字などを...
-
divタグ内のコンテンツが重なっ...
-
excel vba で ulタグのなかのse...
-
横並びのリストで左端がはみ出る
-
複数の画像を横並びにし、その...
-
CSS質問:大手サイトを見ると何...
-
ol、liをスタイルシートで中央寄せ
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
リストマーカーをボックス内に...
-
<table>の高さ固定。情報増加時...
-
ulタグやliタグの中でbrタグ...
-
html/cssの、navを2段にする...
-
リストの数字のフォントサイズ...
-
liタグの中に<p>タグやら<dl>を...
-
CSSでつくったメニューのアニメ...
-
htmlの<ol>タグで、数字などを...
-
ページを開いているときのリン...
-
リンク文字同士の間隔を開ける...
-
レスポンシブWebデザインでリン...
-
<ul><li></li></ul>にするメリ...
-
divタグ内のコンテンツが重なっ...
-
HTMLで組織図を作成する方法
-
ulとliで囲った文字の一部を変...
-
HTML5のfooterに見出しを付けて...
-
<ul>~</ul>が二つ続くと間に改...
-
html <ul></ul>の並びで一行空...
-
複数行にまたがる括弧を表示し...
-
画像にリンクを張ると画像がず...
おすすめ情報