可変幅でabsoluteを指定すると中央配置できなくなります。
ブラウザの幅に合わせて中身のサイズも合わせて伸縮するサイトを構築したくて色々試しているのですが、どうしてもうまくできません。
どのように指定したらできるのでしょうか?困っています、どなたかお助けください。
例えば画像が固定のサイズであれば
width:500px;
position:absolute;
left:50%;
margin-left:-250px;
見たいな形で中央配置できるのですが、可変の場合、、伸縮させたいので、横幅は常に500pxとはなりません。
よろしくお願い致します。
No.2ベストアンサー
- 回答日時:
質問の意味がよくわからないのだが、left:50%なんてものをどーしても使わないといけないの?
素直に考えて
width:80%;
position:absolute;
left:10%;/*100%からwidthの80%を引いたものを左右に均等に開けると10%になります。*/
じゃダメなの?
または、質問に既にある、左右のマージンをautoじゃだめなの?
ブラウザの幅に合わせて中身のサイズも合わせて伸縮するサイトはどちらでもできてると思うが、なぜ、左右のマージンをautoで成功しているにも関わらず、positionをつかいたがらるのかを説明せよ。
autoで中央にくるにも関わらず、困っている理由を説明せよ。
width:80%;
position:absolute;
left:10%;/*100%からwidthの80%を引いたものを左右に均等に開けると10%になります。*/
ありがとうございます!!目からうろこです!!お二方のご回答のおかげで、%基準の捕らえ方の仕組みがわかりました。本当に助かりましたありがとうございます。
あと、autoの件なのですが、通常フローでは成功しているのですが、画像の重なりを演出したいため、position指定をして高さの位置を調整すると、なぜかmargin:0 auto;が無効になり困っていました。float:left;のように常左上に張り付いてしまっている状態でした。
No.3
- 回答日時:
いえ、とても、簡単にできます。
画像は「置換インライン要素」なので、サイズは置換された画像のサイズに依存しますが、スタイルシートで抱合親ブロックのサイズを参照できるブロック要素に変えればよいだけです。
たとえばアルバム写真のリストがある場合・・ウィンドウサイズをどのように変えても伸縮します。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html lang="ja">
<head>
_<meta http-equiv="content-type" content="text/html; charset=Shift_JIS">
_<title>サンプル</title>
_<meta name="author" content="ORUKA1951">
_<meta http-equiv="Content-Style-Type" content="text/css">
_<link rev="made" href="mailto:oruka1951@hoge.com" title="send a mail" >
_<link rel="START" href="../index.html">
_<style type="text/css">
<!--
html,body{margin:0;padding:0;}
h1{text-align:center;}
ul.photoAlbum,ul.photoAlbum li{display:block;list-style:none;margin:0;padding:0;width:100%;}
ul.photoAlbum li img{display:block;width:60%;height:auto;margin:0 auto;}
ul.photoAlbum li+li img{width:40%;}
ul.photoAlbum li+li+li img{width:30%;}
ul.photoAlbum li+li+li+li img{width:20%;}
ul.photoAlbum li+li+li+li+li img{width:10%;}
-->
_</style>
</head>
<body>
_<h1>サンプル</h1>
_<ul class="photoAlbum">
__<li><img src="./images/photo/01.jpg" width="480" height="360" alt="家族みんなで"></li>
__<li><img src="./images/photo/02.jpg" width="480" height="360" alt="娘"></li>
__<li><img src="./images/photo/03.jpg" width="480" height="360" alt="息子"></li>
__<li><img src="./images/photo/04.jpg" width="480" height="360" alt="父"></li>
__<li><img src="./images/photo/05.jpg" width="480" height="360" alt="母"></li>
_<ul>
</body>
</html>
ORUKA1951様 先日のお答えも含めまして本当にありがとうございます。
おっしゃられる上記の内容margin:0 auto;でできました。驚きです!また自身がしたかった画像の重なり等や配置を色々挑戦してみましたが、おどろくようにできるようになりました。今回お三方に、それぞれの角度からご指導頂けた事が、すごく良かったと思います。cssのmarginとpositionの仕組みがすごく理解できました。
本当に感謝の限りです。ありがとうございました。
No.1
- 回答日時:
これ結構悩んでたことがあって、今やってみたのですが、意外にすぐ出来たので回答させて頂きます。
position: absolute;のときはmargin-leftにマイナスを指定するんですね。勉強になりましたw
参考画像から察して、可変幅80%だとすれば、次のようにかけばうまくいきました。
width: 80%;
margin-left: -40%;
position: absolute;
left: 50%;
widthとmarginで単位を揃えればおkってことなんでしょうかね
ありがとうございます!!私もうまくできました!!。80%に対しての半分の50%という考えかたではなく40%が半分になるんですね。
基準の考え方が間違っていたんですね。本当に助かりましたありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- HTML・CSS スクロールすると追従する画像のコードを書いているのですが、追従する画像の大きさの調節が上手くいきませ 2 2022/04/18 12:52
- JavaScript 画像の表示位置 3 2022/12/23 08:25
- HTML・CSS img と p を縦中央に配置したいのですがうまくいきません。 2 2023/01/12 14:38
- Excel(エクセル) 【エクセルマクロ】既に開いているIEの、サイズや表示位置を変更するには 4 2022/12/01 22:57
- Visual Basic(VBA) 【VBA】写真の貼り付けコードがうまく機能しません。 5 2022/09/01 18:43
- HTML・CSS CSS上での計算を行うためのルールについて教えてください。 3 2022/08/15 14:43
- HTML・CSS 下にスクロールしても、追従するボタンのコードを書いたのですが、ボタンの中の画像が半分しか表示されない 1 2022/04/16 21:31
- JavaScript 画面に表示したらアニメーションを開始したい 3 2023/01/13 15:38
- その他(Microsoft Office) エクセルのマクロでスライサー教えてください。 1 2022/09/28 16:40
- JavaScript jQueryでのドラッグアンドドロップについて 1 2022/07/30 09:10
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
<ul>~</ul>が二つ続くと間に改...
-
excel vba で ulタグのなかのse...
-
IEで<td>の全角を有効にする方法
-
プルダウンリストとテキストエ...
-
<table>の高さ固定。情報増加時...
-
ulとliで囲った文字の一部を変...
-
<ul><li></li></ul>にするメリ...
-
css ol liにdisplay:inlineを設...
-
番号付きリスト(<Ol><Li>・・...
-
隙間をなくすには?
-
html <ul></ul>の並びで一行空...
-
複数行にまたがる括弧を表示し...
-
画像をレスポンシブだと 二つず...
-
ページを開いているときのリン...
-
疑似クラス :activeが効きません
-
画像を縦に4つ並べたい場合
-
【CSS】メニュー上部に固定させ...
-
レスポンシブWebデザインでリン...
-
「CSS」リストの2段組どのよう...
-
html/cssの、navを2段にする...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
リストマーカーをボックス内に...
-
番号付きリスト(<Ol><Li>・・...
-
liタグの中に<p>タグやら<dl>を...
-
<table>の高さ固定。情報増加時...
-
レスポンシブWebデザインでリン...
-
<ul><li></li></ul>にするメリ...
-
リストの数字のフォントサイズ...
-
HTMLで組織図を作成する方法
-
ulタグやliタグの中でbrタグ...
-
divタグ内のコンテンツが重なっ...
-
画像にリンクを張ると画像がず...
-
複数行にまたがる括弧を表示し...
-
html <ul></ul>の並びで一行空...
-
ページを開いているときのリン...
-
HTML5のfooterに見出しを付けて...
-
html/cssの、navを2段にする...
-
<ul>~</ul>が二つ続くと間に改...
-
htmlの<ol>タグで、数字などを...
-
リンク文字同士の間隔を開ける...
-
CSSでつくったメニューのアニメ...
おすすめ情報