可変幅で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を探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
リストマーカーをボックス内に...
-
疑似クラス :activeが効きません
-
HTMLでメニューをリストで書き...
-
(HP作成)メニューバーのプル...
-
箇条書きがずれて表示されてし...
-
<ul>~</ul>が二つ続くと間に改...
-
文法チェックの<A>と</A>の間が...
-
ドロップダウンの残像
-
SWIFTでHtmlのソースの一部を取得
-
bxsliderの画像が左によってしまう
-
画像を縦に4つ並べたい場合
-
リンク文字同士の間隔を開ける...
-
display:table;を多段表示させたい
-
<table>の高さ固定。情報増加時...
-
HTMLを教えてください。選...
-
HTMLで組織図を作成する方法
-
htmlの表について、こんな表を...
-
html <li>の中の文字一部に色を...
-
番号付きリスト(<Ol><Li>・・...
-
画像がかなり大ので全体的に1/...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
html/cssの、navを2段にする...
-
リストマーカーをボックス内に...
-
リストの数字のフォントサイズ...
-
<ul><li></li></ul>にするメリ...
-
ulタグやliタグの中でbrタグ...
-
レスポンシブWebデザインでリン...
-
<ul>~</ul>が二つ続くと間に改...
-
HTML5のfooterに見出しを付けて...
-
htmlの<ol>タグで、数字などを...
-
ulとliで囲った文字の一部を変...
-
番号付きリスト(<Ol><Li>・・...
-
HTMLで組織図を作成する方法
-
複数行にまたがる括弧を表示し...
-
liタグの中に<p>タグやら<dl>を...
-
display:table;を多段表示させたい
-
divタグ内のコンテンツが重なっ...
-
<table>の高さ固定。情報増加時...
-
html <ul></ul>の並びで一行空...
-
テーブル内のプルダウンの下に...
-
【至急】ul li 行間調整ができ...
おすすめ情報