2009-06-23 11 views
0

問題の動作を確認するには、this linkをクリックします。次に、this oneをクリックします。どのようにイメージが押しつぶされていることに注目してください(あなたはそれを見るためにページャを通してaをクリックしなければならないかもしれません)。jQueryを使用した画像のスケーリング - ブラウザキャッシュの変更

私はそれがブラウザのキャッシュのためだと思います。ここで仕事をしてジャバスクリプトです:

$("#grid_slider").slider({ 
    value: 50, 
    max: 100, 
    min: 10, 
    slide: function(event, ui) { 
     $('ul#grid li').css('font-size',ui.value+"px"); 
    } 
}); 

$("ul#grid li img").each(function() { 
    var width = $(this).width()/125 + "em"; 
    var height = $(this).height()/125 + "em"; 
    $(this).css("width",width); 
    $(this).css("height",height); 
}); 

私はあなたが問題を再現することができます願っています。これを修正するために何をする必要があるのか​​分かりません...機能をすべて一緒に取り出すことを考えていました。前もって感謝します。

+0

私はあなたのページを見たのにまだ問題を理解していません。 – karim79

+0

「スカッシュ」ってどういう意味ですか?ページを読み込むと、画像が大きく見える部分がちらつき、縮小します。それはあなたが指していることですか? –

+0

さて、私はあなたが問題を再現できないのではないかと心配しました。それは、最初の負荷で動作するように見えます...画像の順序が変わると画像の一部が「盛り上がり」になります。 私はおそらく説明するのは少し難しいです...うまくいけば、自分自身以外の誰かがこのページにアクセスしたときに問題が起こることを願っています。 – Chaddeus

答えて

0

あなたが説明している問題があります。私はそれが実際にはブラウザのキャッシュだとは思っていませんが、ロード時間は...私はいくつかの他のサイトでも問題を見てきました。

主な問題は、それはそれが何であるかを知っている前にブラウザが$(document).readyに...あなたのスクリプト火災を画像の大きさを要求されていることですが、$("ul#grid li img")は、完全にロードされる前にそれはあるかもしれないと思われるいくつかの画像$("ul#grid li img").width()ためそう知られていないかもしれません...

多分これを代わりに使用して、役立つかどうかを確認してください。 (スイッチ$().load$().each

$("ul#grid li img").load(function() { 
    var width = $(this).width()/125 + "em"; 
    var height = $(this).height()/125 + "em"; 
    $(this).css("width",width); 
    $(this).css("height",height); 
}) 

(完全に推測、しかし...)

補遺:ちょうど今ロード機能にjQueryのヘルプを読んで、ために実行されないことが表示されますこれが呼び出された時点ですでに読み込まれているもの...だから、両方とも行う必要があるかもしれません($().eachと設定して$().loadを設定してください)...

+0

うーん...それは理にかなっています。サイズ変更を遅らせるか、読み込み時に画像サイズをハードコーディングします。 – Chaddeus

関連する問題