2019.07.23
この記事は約18分で読めます。
記事の内容に行く前に、この記事を読む時間の表示について先にお知らせです。記事の最初に「この記事は約xx分で読めます。」と出てきますが、この記事では約18分と出る!(汗)
自動計測による分数表示なのですが、実際そこまでかかりません。記事内に出てくる画像エンコード文字によるのではないかと考えられます。10分未満かなと思います。ご了承ください。
先日書いたサイトの軽量化:Webフォントに続き、今度は画像による軽量化を考えます。Test My Siteによる指摘の中で主に画像に関するのは★印の部分です。ただ後にも書きますが全ての対策を行うことは今回しません。理由も併記します。
先に書きますがこの対策は今回行っていません。後に詳細を書きますがブラウザがまだ対応しきれていないフォーマットだからです。ブラウザによって表示されたりされなかったりを考えてあれこれ今触るのは無駄というか「修正が今じゃない」かなと思います。ブラウザもどんどん進化していくので今後を見守りたいと思います。詳細を知らなくてよい場合は次の適切なサイズの画像を用意するへお進みください。
まず「次世代フォーマット」って何?と思いますよね。Test My Siteの説明にはこうあります。
JPEG 2000、JPEG XR、WebP で画像をエンコードすると、読み込み時間が短くなり、モバイル通信のデータ量も少なくすることができます。フォールバック用に PNG 画像や JPEG 画像も用意し、未対応ブラウザにはそちらを配信するようにしましょう。
JPEG 2000、JPEG XR、WebPはあまり馴染みないかもしれませんが、フォーマットと呼ばれる種類です。PNGやJPEGをこれらのフォーマットに変換するとより軽量化を図れるというものです。試しにこの記事でサンプルを置いてみます。
残念。Photoshopにプラグインを入れXRに保存しなおしたら0バイト…。なのでオンラインで挑戦。試したのはaconvert.com
これもオンラインで変換を行いました。WEBP変換ツール (jpg、pngとwebpを相互変換)
例を挙げて見てきましたが先にも書いたこの対策をしなかった理由、それはブラウザ対応がまだ完全でないところにあります。Googleの提案は常に先を進み後から他がついて行ってるような印象を受けます。2018年12月現在のブラウザ対応表を分かりやすく記載されている方がいらっしゃいますのでリンクを貼ります。
主要ブラウザごとのJPEG2000 / JPG XR / WebP画像対応状況
フォーマットによってばらつきがありますよね。この不安定さだとスピード重視のためにいくつも画像を用意しないといけないし、画像枚数によってはサーバ容量を圧迫すると思います。もちろんJPEGでもPNGでも枚数や容量で圧迫するのですが、今のタイミングで無理やり軽さを求めず、もう少し様子見しようというわけです。
一番分かりやすくできそうなところです。縦横サイズという意味合いもありますが、目に見えて大きい小さいが分かるものだけでなく、容量のほうが色々と調整が必要です。
ちなみに先に言いますが、Google PageSpeed Insightsに従って画像を最適化すると粗い画像になることがあります。
※今はリンクがないのかサービスが変わったのか分からないのですが、かなり前に指示に沿ってページ内リンクからやってみたら、ひどい画像になるものもありました(汗)
なので荒れない程度に容量を落とすことが必要になります。
今回このサイトでもサイズと容量をいくつか落としました。全部書くと大変な数なので代表例としてTOPのメインイメージは容量を1/4ほどにしています。
画像最適化で検索するとよく出てくるお馴染みのサイト。パンダが目印です。
特にpng画像が荒くなりすぎず最適化できますね。
今度はワニが目印です。アニマルキャラ多いな~w
https://imagecompressor.com/ja/
画質を確認しながら調整できるのがいいですね。
うって変わってシンプルなサイトです。ほかにもツールがあるので便利ですよ。
https://www.iloveimg.com/ja/compress-image
こちらも日本語で分かりやすい。
「画像を効率的にエンコードする」とは?にも、Test My Siteの説明があります。
帯域幅の取り合いが少ないほど、ブラウザがコンテンツをダウンロードして画面に表示するまでの時間も短くなります。画像を最適化することで、ウェブサイトのパフォーマンスが向上します。
先に書きますがこの対策も今回行っていません。エンコードすることでサーバへのリクエストの負担を減らせることは分かるのですが、意外に手間もかかるためです。
ちなみにこの記事のアイキャッチ(タイトルの背景画像)をエンコードすると以下になります。
※エンコードすると容量としては増えます。なので大きい画像はフリーズしちゃいますので、100×75ピクセルと小さくしてやってみます。
変換に使用したのはオンラインツールBase64エンコーダーです。
文字列でも画像が表示できるというサンプルです。元の画像が4.24KB、エンコードすると5.67KBになります。容量よりもリクエストを減らすというのが目的なのですね。
詳細を分かりやすく書かれている方がいらっしゃいますのでリンクを貼ります。
「合理的なキャッシュポリシーで静的アセットを配信する」え?え?って? 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>
対策していないもの+対策の一部を行っていない(画像の圧縮も見栄えの関係で限界があるから)ので、Googleからの指摘は消えませんがPageSpeed Insightsでは少々改善されました。
ここまで書いておいていうのもなんですが…
と思うのです。
少し脱線しますが、昔務めていた会社で駆け出しの頃、HTMLの記述をW3Cでパーフェクト目指せと言われてきたのですが、そこで小さい事件がありました。まだXHTMLだった頃のことで、metaタグにreply-toでメールアドレスを書き、このサイトへの連絡先として書くという頃がありました(今でも記述は問題ないのかな、使用していないので知らないのですが)。結論言えば書かなくても減点にはならないので個人的に採用していませんでした。しかし人によっては指摘無しを目指したためにメールアドレス書いちゃって、結果スパムメールが来るようになった…という話もあるほどです。
つまり最善のサイトにするために必要なことだけれど、最終目的が何であるのかを見失わないようにしないといけないので、ある程度は検討も必要だと思います。ソースを美しくするのもサイトを軽量化するのもナチュラルなSEOや閲覧される方の満足度へのためなのですから。
サイトを軽量化したいと思う方のお役に立つ記事になっていれば幸いです。
によ
コメントをどうぞ