笑顔計画|デザイナー's WEB SITE

サイトの軽量化:画像

2019.07.23

この記事は約18分で読めます。

記事の内容に行く前に、この記事を読む時間の表示について先にお知らせです。記事の最初に「この記事は約xx分で読めます。」と出てきますが、この記事では約18分と出る!(汗)
自動計測による分数表示なのですが、実際そこまでかかりません。記事内に出てくる画像エンコード文字によるのではないかと考えられます。10分未満かなと思います。ご了承ください。

 

先日書いたサイトの軽量化:Webフォントに続き、今度は画像による軽量化を考えます。Test My Siteによる指摘の中で主に画像に関するのは★印の部分です。ただ後にも書きますが全ての対策を行うことは今回しません。理由も併記します。

 

  1. ウェブフォントの読み込み中もテキストを表示する(解決済み)
  2. 次世代フォーマットで画像を配信する★
  3. CSSを軽量化する
  4. レンダリングを妨げるリソースを削除する
  5. 適切なサイズの画像を用意する★
  6. テキストの圧縮を有効にする
  7. 不要なCSSを削除する
  8. 画像を効率的にエンコードする★
  9. ネットワーク ペイロードを過度に大きくしない
  10. 合理的なキャッシュポリシーで静的アセットを配信する★

 

 

画像|目次

 

次世代フォーマットで画像を配信する

先に書きますがこの対策は今回行っていません。後に詳細を書きますがブラウザがまだ対応しきれていないフォーマットだからです。ブラウザによって表示されたりされなかったりを考えてあれこれ今触るのは無駄というか「修正が今じゃない」かなと思います。ブラウザもどんどん進化していくので今後を見守りたいと思います。詳細を知らなくてよい場合は次の適切なサイズの画像を用意するへお進みください。

まず「次世代フォーマット」って何?と思いますよね。Test My Siteの説明にはこうあります。

JPEG 2000、JPEG XR、WebP で画像をエンコードすると、読み込み時間が短くなり、モバイル通信のデータ量も少なくすることができます。フォールバック用に PNG 画像や JPEG 画像も用意し、未対応ブラウザにはそちらを配信するようにしましょう。

JPEG 2000、JPEG XR、WebPはあまり馴染みないかもしれませんが、フォーマットと呼ばれる種類です。PNGやJPEGをこれらのフォーマットに変換するとより軽量化を図れるというものです。試しにこの記事でサンプルを置いてみます。

元画像JPEG
  • 笑顔計画のマークです
  • サンプルに使用したのはこの画像です。640×480ピクセルで25.6KB。
JPEG2000
  • 見えない場合のテキストです
  • 左の画像が見えるならば、JPEG2000に対応したブラウザです。見えない場合はテキストで「見えない場合のテキストです」と表示されます。同サイズで73.7KB。元々のJPEGをJPEG JP2 変換。Convertioで変更してみました。なぜか容量は大きくなりました…。
  • 見えない場合のテキストです
  • 左の画像が見えるならば、JPEG2000に対応したブラウザです。見えない場合はテキストで「見えない場合のテキストです」と表示されます。同サイズで44.8KB。今度はPhotoshopからJPEGを開いてJPEG2000として保存しました。さっきのコンバーターよりは軽いようですが、元画像よりは容量大きい…。
JPEG XR

残念。Photoshopにプラグインを入れXRに保存しなおしたら0バイト…。なのでオンラインで挑戦。試したのはaconvert.com

  • 見えない場合のテキストです
  • 左の画像が見えるならば、JPEG XRに対応したブラウザです。見えない場合はテキストで「見えない場合のテキストです」と表示されます。同サイズで119KB。これもなぜか容量は大きくなりました…。
WebP

これもオンラインで変換を行いました。WEBP変換ツール (jpg、pngとwebpを相互変換)

  • 見えない場合のテキストです
  • 左の画像が見えるならば、webPに対応したブラウザです。見えない場合はテキストで「見えない場合のテキストです」と表示されます。同サイズで10KB。これは軽くなりましたね!

 

例を挙げて見てきましたが先にも書いたこの対策をしなかった理由、それはブラウザ対応がまだ完全でないところにあります。Googleの提案は常に先を進み後から他がついて行ってるような印象を受けます。2018年12月現在のブラウザ対応表を分かりやすく記載されている方がいらっしゃいますのでリンクを貼ります。

主要ブラウザごとのJPEG2000 / JPG XR / WebP画像対応状況

フォーマットによってばらつきがありますよね。この不安定さだとスピード重視のためにいくつも画像を用意しないといけないし、画像枚数によってはサーバ容量を圧迫すると思います。もちろんJPEGでもPNGでも枚数や容量で圧迫するのですが、今のタイミングで無理やり軽さを求めず、もう少し様子見しようというわけです。

適切なサイズの画像を用意する

一番分かりやすくできそうなところです。縦横サイズという意味合いもありますが、目に見えて大きい小さいが分かるものだけでなく、容量のほうが色々と調整が必要です。
ちなみに先に言いますが、Google PageSpeed Insightsに従って画像を最適化すると粗い画像になることがあります。
※今はリンクがないのかサービスが変わったのか分からないのですが、かなり前に指示に沿ってページ内リンクからやってみたら、ひどい画像になるものもありました(汗)
なので荒れない程度に容量を落とすことが必要になります。

今回このサイトでもサイズと容量をいくつか落としました。全部書くと大変な数なので代表例としてTOPのメインイメージは容量を1/4ほどにしています。

 

TinyPNG:pngの最適化におススメ

画像最適化で検索するとよく出てくるお馴染みのサイト。パンダが目印です。

https://tinypng.com/

特にpng画像が荒くなりすぎず最適化できますね。

 

Optimizilla:日本語対応&サンプル画像表示ありでオススメ

今度はワニが目印です。アニマルキャラ多いな~w

https://imagecompressor.com/ja/

画質を確認しながら調整できるのがいいですね。

I love IMG:gif画像の圧縮もできる

うって変わってシンプルなサイトです。ほかにもツールがあるので便利ですよ。

https://www.iloveimg.com/ja/compress-image

こちらも日本語で分かりやすい。

画像を効率的にエンコードする

「画像を効率的にエンコードする」とは?にも、Test My Siteの説明があります。

帯域幅の取り合いが少ないほど、ブラウザがコンテンツをダウンロードして画面に表示するまでの時間も短くなります。画像を最適化することで、ウェブサイトのパフォーマンスが向上します。

先に書きますがこの対策も今回行っていません。エンコードすることでサーバへのリクエストの負担を減らせることは分かるのですが、意外に手間もかかるためです。
ちなみにこの記事のアイキャッチ(タイトルの背景画像)をエンコードすると以下になります。
※エンコードすると容量としては増えます。なので大きい画像はフリーズしちゃいますので、100×75ピクセルと小さくしてやってみます。

変換に使用したのはオンラインツールBase64エンコーダーです。

 

 


文字列でも画像が表示できるというサンプルです。元の画像が4.24KB、エンコードすると5.67KBになります。容量よりもリクエストを減らすというのが目的なのですね。

 

詳細を分かりやすく書かれている方がいらっしゃいますのでリンクを貼ります。

につけておきたいWebサイト高速化テクニック #5|リクエスト数削減テクニック01:インラインイメージ編

合理的なキャッシュポリシーで静的アセットを配信する

「合理的なキャッシュポリシーで静的アセットを配信する」え?え?って? Test My Siteの説明があります。

HTTP キャッシュを使用すると、ユーザーが再度訪れた際のページの読み込み時間を短縮できます。再訪時にページを迅速に表示できるよう、キャッシュの有効期間を長くしておきましょう。

…キャッシュ時間の設定ですね。基本は.htaccessに記述でいいと思います。
これも詳しく記載されている方がいらっしゃいますのでリンクを貼ります。

.htaccessファイルのブラウザキャッシュ設定方法!最適化してページを高速表示させる

私もいくつか参考にして、下記のように記述しました。

<IfModule mod_expires.c>
ExpiresActive On
ExpiresByType image/gif "access plus 1 months"
ExpiresByType image/jpg "access plus 1 months"  
ExpiresByType image/jpeg "access plus 1 months" 
ExpiresByType image/png "access plus 1 months"
ExpiresByType image/svg+xml "access plus 1 months" 
ExpiresByType image/x-icon "access plus 6 months" 
ExpiresByType text/css "access plus 1 months" 
ExpiresByType text/javascript "access plus 1 months" 
ExpiresByType application/javascript "access plus 1 months" 
ExpiresByType application/x-javascript "access plus 1 months"
ExpiresByType application/x-font-woff "access plus 1 months"
</IfModule>

修正後、再度Test My siteで確認

対策していないもの+対策の一部を行っていない(画像の圧縮も見栄えの関係で限界があるから)ので、Googleからの指摘は消えませんがPageSpeed Insightsでは少々改善されました。

補足:軽くすることは大事だけれど

ここまで書いておいていうのもなんですが…

  • Test My Siteでの指摘やPageSpeed Insightsでの改善はとても大事!だけれど…
  • パーフェクトを目指す=閲覧者にとって最善だとは言えない

と思うのです。

 

少し脱線しますが、昔務めていた会社で駆け出しの頃、HTMLの記述をW3Cでパーフェクト目指せと言われてきたのですが、そこで小さい事件がありました。まだXHTMLだった頃のことで、metaタグにreply-toでメールアドレスを書き、このサイトへの連絡先として書くという頃がありました(今でも記述は問題ないのかな、使用していないので知らないのですが)。結論言えば書かなくても減点にはならないので個人的に採用していませんでした。しかし人によっては指摘無しを目指したためにメールアドレス書いちゃって、結果スパムメールが来るようになった…という話もあるほどです。

つまり最善のサイトにするために必要なことだけれど、最終目的が何であるのかを見失わないようにしないといけないので、ある程度は検討も必要だと思います。ソースを美しくするのもサイトを軽量化するのもナチュラルなSEOや閲覧される方の満足度へのためなのですから。
サイトを軽量化したいと思う方のお役に立つ記事になっていれば幸いです。

によ

カテゴリ一覧へ戻る

コメントをどうぞ

メールアドレスは非公開です。お気軽にコメントください。全項目入力必須項目です。

CAPTCHA


このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください

プライバシーポリシー

Copyright© 笑顔計画 All rights reserved.