• 締切済み

firefoxでプリロードされません

マウスが乗るまで画像がよみこまないので、 画像を先に読み込ませるためのものを入力したところ safariでは希望通りに動いたのですが、 firefoxでは入力前と全く変わりません。 何か間違っているのか、教えてください。 お願いします! 以下がcssに入力したものです。 #image-preload{ width: 0px; height: 0px; display: inline; background-image:url('images/home_04.jpg'); } 以下がhtmlに入力したものです。 <div id="image-preload"></div>

みんなの回答

  • abril
  • ベストアンサー率69% (388/560)
回答No.3

拝見しました…仕組みはわかりましたが、あくまで個人的意見ですが、ロールオーバー用画像のプリロードの為だけに無意味なマークアップをしている事も含め、CSSの用法としてはちょっと邪道な感じがします。こういう事をするぐらいだったらJavaScriptでプリロードさせておくか、複数の背景画像の差し替えではなく同一画像にして位置をずらして表示させる手法の方がまだ理にかなっている気がしますが… ところで、ちょっとググっていたらこの方法を試された方の記事がありました。 http://www.orenoi.com/?blogid=1&archive=2006-09 (2006 September 08,Friday の記事です) …だそうですが、同じ事をなさっていたりはしませんか?(ソースを見る限りは、一つの背景画像しか指定していない様ですが)。 いずれにせよ、「safariでは希望通りに動いたのですが、firefoxでは入力前と全く変わりません。」というのであれば、Firefoxでは上記の様なCSSによる記述ではプリロードの効果を果たせない仕様なのだと思われます。少なくともこの方法を使うという前提では、CSSの指定をどうこうすれば各ブラウザへの対応状況が解決できる、という事にはならないのでは…

noname#66720
noname#66720
回答No.2

プリロードが必要ということはメニュー等のロールオーバーですか?? その場合、プリロードした画像を使うソースの方を改善する方が早そうですが。

  • abril
  • ベストアンサー率69% (388/560)
回答No.1

ちょっと状況がよくわからないのですが…「マウスが乗るまで画像がよみこまないので、画像を先に読み込ませるためのもの」と仰っていますが、CSSは「プリロード」「先に読み込ませる」という機能を管轄するものではありませんが? 質問者様の意図されている事の全体像が見えないのですが、単純に、提供されたCSSとHTMLのソースだけを見ると、いくつかのおかしな点があります。 #image-preloadのスタイルを"width: 0px; height: 0px;"としていますが、これだと幅も高さも0の為、同時に指定している背景"background-image:url('images/home_04.jpg');"は全く表示されない事になります。また、併せて"display: inline;"も指定していますが、インライン要素にしてしまうと幅や高さは指定できません。矛盾しています。 何をなさりたいのでしょうか?

chocoholi9
質問者

補足

http://phpspot.org/blog/archives/2006/04/css_2.html このページをみて、この文章をhtmlとcssに追加してみたのですが、 firefoxでは上手く動かないんです、、

関連するQ&A

専門家に質問してみよう