みんなの「教えて(疑問・質問)」にみんなで「答える」Q&Aコミュニティ

こんにちはゲストさん。会員登録(無料)して質問・回答してみよう!

解決済みの質問

IE6でmax-width:100px; max-height:100pxを実現にするには

BLOGでエントリーから画像だけを読み出しサムネイルを集めたhttp://www.photocase.com/photobrowser.aspのようなページを作ろうと考えています。
画像の大きさはまちまちなのでmax-width:100px; max-height:100pxとしました。
しかしmax/min-height/widthはIE6に対応しません。
そこで▼以下の2つを試してみました。
・max-width in Internet Explorer(IE独自のexpressionを利用)
 http://www.svendtofte.com/code/max_width_in_ie/
・minmax.js module(Java Scriptを利用)
 http://doxdesk.com/software/js/minmax.html
ただしこれらの使用方法に従って記載しても、max-width:100px; height:100px(縦長の画像は100px×100pxに)またはwidth:100px; max-height:100px(横長の画像は100px×100pxに)となってしまいます。
Java Script、CSS、または両方を使って解決できる方法がありましたら教えていただけませんでしょうか。
よろしくお願いいたします。

投稿日時 - 2006-11-05 23:10:23

QNo.2520326

すぐに回答ほしいです

質問者が選んだベストアンサー

#1です。

> これをサムネイルの表示をする時点でそれぞれ本来の縦横比率に表示する
> ことは難しいでしょうか。

これではどうでしょう。個々のサムネイルごとに修正をかけるので、少しはましかと……。

<html>
<head>
<style type="text/css"><!--
/* 100x100の領域だけ取って、表示しない。 */
img.thumb { visibility: hidden; width: 100px; height: 100px; }
/* ただし、これではスクリプトOFFだと全く表示されない。 */
--></style>
<script type="text/javascript"><!--
function func(img) {
/* 一旦縦横とも"auto"にして実寸を取得。長い方を"100px"に再設定。そして表示。 */
img.style.width = "auto";
img.style.height = "auto";
if (img.width > img.height) {
if (img.width > 100) img.style.width = "100px";
} else {
if (img.height > 100) img.style.height = "100px";
}
img.style.visibility = "visible";
}
--></script>
</head>
<body>
<p>
<img class="thumb" src="適当な画像1" onload="func(this)">
<img class="thumb" src="適当な画像2" onload="func(this)">
<img class="thumb" src="適当な画像3" onload="func(this)">
</p>
</body>
</html>

投稿日時 - 2006-11-07 21:33:07

お礼

tabideさん、ご丁寧に教えていただいてありがとうございました。
イメージしていたものとピッタリの結果で大変うれしいです。
心からお礼を申し上げます。
ありがとうございました。

投稿日時 - 2006-11-08 23:21:32

ANo.3

このQ&Aは役に立ちましたか?

0人が「このQ&Aが役に立った」と投票しています

回答(3)

ANo.2

IE7では max-width,max-height 対応しました。
参考までに。
http://www.microsoft.com/japan/windows/ie/

投稿日時 - 2006-11-06 12:14:03

お礼

IE7が普及すれば各ブラウザ間の見え方を調整するこのような面倒な作業から解放されるかもしれませんね。

投稿日時 - 2006-11-07 15:19:43

ANo.1

試しに作ってみました。こんなんでどうでしょう。

<html>
<head>
<style type="text/css"><!--
/* スクリプトOFFの場合。これでも実寸表示よりはまし。 */
img.thumb { width: 100px; height: 100px; }
--></style>
<script type="text/javascript"><!--
function func() {
list = document.getElementsByTagName("img");
for (i = 0; i < list.length; i++) {
if (list[i].className == "thumb") {
/* 一旦縦横とも"auto"にして実寸を取得。長い方を"100px"に再設定。 */
list[i].style.width = "auto";
list[i].style.height = "auto";
if (list[i].width > list[i].height) {
if (list[i].width > 100) list[i].style.width = "100px";
} else {
if (list[i].height > 100) list[i].style.height = "100px";
}
}
}
}
--></script>
</head>
<body onload="func()">
<p>
<img class="thumb" src="適当な画像1">
<img class="thumb" src="適当な画像2">
<img class="thumb" src="適当な画像3">
</p>
</body>
</html>

投稿日時 - 2006-11-06 07:48:38

補足

tabideさん、お返事が遅くなってスミマセン。
まさにやりかったことがこんなにも短いコードで実現できて大変うれしいです。
ただ、もし可能であればもうひとつだけ教えていただけませんでしょうか。
現在のコードだと横長も縦長もいったん100px×100pxで表示され、
エントリーから読み出しが終わった段階で本来の縦横比率に修正されます。
これをサムネイルの表示をする時点でそれぞれ本来の縦横比率に表示する
ことは難しいでしょうか。
サムネイルがすべて表示された後で、画像の縦横比率が変更されると
「何が起きたんだろう」と少し違和感を感じます。
お知恵をお借りできれば幸いです。

投稿日時 - 2006-11-07 15:19:01

あなたにオススメの質問