2012-04-13 7 views
0

必要なすべてのイメージを手動でプリロードするスクリプトがあります。これは次のようになります。イメージプリロード問題

実際には、すべてのタイプのボタンやその他の要素には、このようなエントリがたくさんあります。最も悪いことは、プロジェクトが進行中であり、新しいボタンが毎日追加されているため、リストに追加するのを忘れてしまうことです。

ここでは、使用中のすべてをプリロードする汎用スクリプトを使用したいと思います。

その後、文書内の(すべてのボタンを取得すると言う、$(「ボタン」))jQueryのようなセレクタを持つすべての要素を列挙しなければならない - これは私にとって最も難しい部分である - あるスタイルを見つけます要素のクラスと 'アクティブな'クラスの結果(混同しないでください:アクティブな擬似クラスですが、違いはありません)。

<button type="button" class="small pink"><p>Menu</p></button> 

そして、次のCSSがある:例えば、

をボタンがあります明らかに

button.pink.large 
{ 
    background-image: url('buttonpinknormal.png'); 
} 
button.pink.large.active 
{ 
    background-image: url('buttonpinkpressed.png'); 
} 
button.pink.small 
{ 
    background-image: url('buttonpinksmallnormal.png'); 
} 
button.pink.small.active 
{ 
    background-image: url('buttonpinksmallpressed.png'); 
} 

は、このボタンにプリロード画像は、小さな」以来、最後の1でなければなりません「ピンク」は明示的に定義されており、「アクティブ」は私たちが探しているものです:

button.pink.small.active 
{ 
    background-image: url('buttonpinksmallpressed.png'); 
} 

estionはスタイルをフィルタリングする方法です。

よろしく、

あなたが見ることができるように

UPDATE、最初にボタンが何の 'アクティブ' なスタイルを持っていません。タッチイベントでスクリプトが追加されています(Android Webkitはreal:activeをサポートしていないため)。そのため、別のスクリプトから画像をプリロードする必要があります。そして、はい、クリック時にアクティブ状態の画像の実行時の読み込みが表示されますが、それはうんざりしています。

+1

'var new_array = $(" html ").html()。一致する(/ url \((+)\)/ g) ' –

+0

私は混乱しています。あなたはあなたのページのCSSからすべての画像URLをつかみ、そのページのjavascriptを使ってそれらのURLをプリロードしようとしていますか?どのような目的のために?使用中のCSSスタイルは、JSの実行前またはその直後にロードされます(ページ内のCSS /スクリプトの相対的な位置によって異なります)。 – jfriend00

+3

なぜスプライトと背景位置を使用しないのですか - http://www.noobcube.com/tutorials/html-css/css-background-image-sprites-a-beginners-guide-/? –

答えて

1

スプライトを使用してbackground-positionを変更するだけで、ブラウザは1回のリクエストを行うだけで、通常の状態を表示する必要があるため、プリロードする必要はありません。また、レンダリングされたイメージを再配置するだけで、状態の切り替えが速くなります(別々のイメージが遅くて効率的ではありません)。

+0

残念ながら、私はすでにバックグラウンドポジションを持つ:center center;共通のスタイルで。そして私は本当にそれが必要です。 – noober

+0

バックグラウンドポジションを取り除くことをお勧めしますか?center center;スプライトを使う依存関係? – noober

+0

OK、それを行います。 – noober