
可変幅で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で質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ulタグやliタグの中でbrタグ...
-
リストマーカーをボックス内に...
-
疑似クラス :activeが効きません
-
<li>タグの数が増えすぎたので...
-
リンク文字同士の間隔を開ける...
-
monacaで使うcssの釦の色を変え...
-
なぜ?マウスオーバーで1pt位置...
-
複数行にまたがる括弧を表示し...
-
IE7でfloat:leftが効かない問題
-
CSSで改行後の行間調整
-
min-heightとheightの違いについて
-
既婚男女の方、結婚前と結婚後...
-
複数のボタンを等間隔に、かつ...
-
H1タグを画像にしたい
-
FC2ショッピングカート 写真の...
-
マージソートの計算量について-...
-
【CSS】ヘッダーの高さが不明の...
-
横スクロールサイトの中央寄せ
-
htmlの文字が縦書きになる
-
XML画像データををHTMLで簡単に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
リストマーカーをボックス内に...
-
liタグの中に<p>タグやら<dl>を...
-
ulタグやliタグの中でbrタグ...
-
divタグ内のコンテンツが重なっ...
-
html/cssの、navを2段にする...
-
list-style-type部分だけ大きく...
-
複数行にまたがる括弧を表示し...
-
html <li>の中の文字一部に色を...
-
ページを開いているときのリン...
-
番号付きリスト(<Ol><Li>・・...
-
リストを2つに分割して、それぞ...
-
リストの左余白の削除方法
-
html <ul></ul>の並びで一行空...
-
<li>タグの数が増えすぎたので...
-
<ul><li></li></ul>にするメリ...
-
css 横並びのナビゲーションバ...
-
htmlの<ol>タグで、数字などを...
-
<li>で改行する横並びのメニュー
-
ページ内リンク!?のしかた
-
イメージマップと画像のスライ...
おすすめ情報