画像の onload イベントとブラウザ キャッシュ
画像のロード後にアラート ボックスを作成する場合、.onload イベントを使用するのが一般的です。ただし、画像がすでにブラウザーにキャッシュされている場合、.onload イベントは発生しません。キャッシュされたステータスに関係なく、すべての画像に対してアラートをトリガーしたい場合、これは課題となる可能性があります。
解決策
この問題を解決するには、実証済みの 2 つの方法があります。メソッド:
方法 1: src の前に onload プロパティを設定する
動的に生成されたイメージは、src 属性の前に onload プロパティを設定することで、onload イベントを適切にトリガーできます:
var img = new Image(); img.onload = function () { alert("image is loaded"); }; img.src = "img.jpg";
方法 2: jQuery の 'load' イベントを使用する
jQuery では、'load' イベントを使用して、キャッシュに関係なくアラートを確実にトリガーできます。
var img = new Image(); // 'load' event $(img).on('load', function() { alert("image is loaded"); }); img.src = "img.jpg";
これらの手法は、キャッシュされた画像とキャッシュされていない画像の両方を効果的に処理し、あらゆる場合にアラートを正常に表示できるようにします。
以上が画像がキャッシュされている場合でも画像の「onload」イベントをトリガーするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。