0
0

ポイント

  • 外部の画像サーバーは安定性の懸念がある
  • 画像を後から差し替える

目的:画像を速く、確実に表示する

前回、外部のサーバーを利用すると画像を高速に表示できることを紹介した。

一方で、外部のサーバーは安定性の懸念があり、サーバーにトラブルが発生すると画像が表示されなくなる問題がある。

そこで、画像を遅延読み込みで差し替えて確実に表示できるようにする。

遅延読み込みの方法

遅延読み込みする画像は、次のように記述する。

<img src="元の画像のURL" data-src="差し替える画像のURL" alt="画像の説明" height="高さ" width="幅"/>

data-src="" という項目を追加して、差し替える画像のURLを記入する。


次に、ページの最後にこの記述を追加する。

<script> //画像の遅延読み込み
    document.addEventListener('DOMContentLoaded', function() {
        setTimeout(function() {
            var slowImages = document.querySelectorAll('img[data-src]');
            slowImages.forEach(function(img) {
            img.setAttribute('src', img.getAttribute('data-src'));
            });
        }, 150); // 150ミリ秒遅延実行
    });
</script>

ページの表示から 0.15 秒後 に、<img>src="" の内容を data-src="" の内容に書き換えている。

このスクリプトは軽量でどこに配置しても良いが、一般的には一番最後の </body> の前に記述する。

実際の動作

実際の差し替えを Chrome の 開発者ツール で確認してみる。


開発者ツール画像差し替えコメント入り.png (1301×253)

ページの読み込みに続いて、初期サーバーの画像が読み込まれる。こちらは読み込みが早い。

ページの読み込み終了から 0.15 秒後に、差し替えるサーバーの画像の読み込みが始まる。こちらは遅く、約1秒 かかっている。

そして、ページ読み込み開始から 2秒後 に、画像が入れ替わっている。

画像差し替えのメリット

  • 画像表示を1秒短縮できる
  • 外部サーバーがサービスを終了しても画像が表示される

画像差し替えのデメリット

  • 画像を2回読み込むのでデータ通信量が増える
  • 画像を挿入する時に少し手間が増える

実際のデメリットは?

データ通信量は、初期画像を高圧縮にすれば問題ない。

画像を挿入する手間も、外部サーバーはトップの画像にのみ使えばよいのでそれほど大変ではない。

参考:通常の遅延読み込みの用途

通常は、遅延読み込みは初期画像に1px × 1px の非常に軽いダミー画像を挿入して、読み込み負荷を減らす目的で使う。

ダミー画像の例:
src=""

現在は、全てのブラウザが <img loading="lazy"> による遅延読み込み対応したので、以前より使うことは少なくなった。

loading="lazy" との比較

loading="lazy" 今回の方法(Javascript)
対象 img と iframe のみ 何でも
タイミング 指定できない 細かく設定できる
最初の画像 使うとスコアが悪化 一応使える
Javascript 無効時 動作する 動作しない

最初の画像に Javascript による遅延読み込みを行うと、スコアは上昇するが実際の画像の表示は遅くなる。

注意:height と width を記入する

画像を遅延読み込みすると、レイアウトシフト(ページの表示がカクッと崩れる)が発生する。

レイアウトシフトは見ていて不快で、さらに再レンダリングのためにパフォーマンスが悪化する。

これを防ぐため、遅延読み込みする場合は height と width を明示的に記入して、レイアウトを保持する。


まとめ

  • 遅延読み込みで画像を差し替える
  • 高速なサーバーを利用しながら、確実に表示できる


次の記事

前の記事


オリジナルのブログ記事

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0