26
14

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

レスポンシブロゴをsvgファイル1つで実現する

Last updated at Posted at 2022-06-14

この記事の概要

レスポンシブロゴをご存じでしょうか。

デスクトップからスマートフォンまで、どんなサイズのディスプレイにロゴが表示されるかは予想がつきません。
同じ見た目のロゴを拡大縮小しても、あまり見目良くならない場合もあるでしょう。

そのためレスポンシブロゴと呼ばれる手法でロゴのバリエーションを定義する企業・サービスもあります。

ただ、これを実現するために毎回srcsetに複数のパスを指定するのも面倒です。1
クライアントにたくさんの種類のロゴを渡して「〇px以下のときはこちらを使ってください」などとお願いするのも申し訳がありません。

というわけで、1つのsvgファイルだけでレスポンシブロゴを実現する方法を記事にしました。

作り方

各パターンのロゴの用意

まずは、すべてのサイズごとのロゴを作ります。

今回は分かりやすいようにLarge Medium Smallの3種類のテキストを並べています。
実際に作る際は、シンボル + ロゴタイプ ロゴタイプのみ シンボルのみのような構成になるでしょう。

1つの矩形の中に配置して、それぞれのパターンが分かりやすいように色分けしておきます。

これをsvgとして書き出します。
現段階ではこんなイメージです。

<svg width="400" height="198" viewBox="0 0 400 198" fill="none" xmlns="http://www.w3.org/2000/svg">
  <path d="..." fill="#FF0000"/> <!-- Smallのパス -->
  <path d="..." fill="#0000FF"/> <!-- Mediumのパス -->
  <path d="..." fill="#00FF00"/> <!-- Largeのパス -->
</svg>

グループに分割

次に、今のsvgをclassつきのグループに分割します。

  <svg width="400" height="198" viewBox="0 0 400 198" fill="none" xmlns="http://www.w3.org/2000/svg">
+   <g class="small">
      <path d="..." fill="#FF0000"/>
+   </g>
+   <g class="medium">
      <path d="..." fill="#0000FF"/>
+   </g>
+   <g class="large">
      <path d="..." fill="#00FF00"/>
+   </g>
  </svg>

メディアクエリの指定

次に、svgの中でメディアクエリを指定します。
今回は以下の設定でいきます。

  • 200px以下
    • Small
  • 200pxから400px以下
    • Medium
  • 400pxから
    • Large
  <svg width="400" height="198" viewBox="0 0 400 198" fill="none" xmlns="http://www.w3.org/2000/svg">
+   <style type="text/css">
+     .large {
+       display: block;
+     }
+     .medium {
+       display: none;
+     }
+     .small {
+       display: none;
+     }
+     @media (max-width: 400px) {
+       .large {
+         display: none;
+       }
+       .medium {
+         display: block;
+       }
+     }
+     @media (max-width: 200px) {
+       .medium {
+         display: none;
+       }
+       .small {
+         display: block;
+       }
+     }
+   </style>
    <g class="small">
      <path d="..." fill="#FF0000"/>
    </g>
    <g class="medium">
      <path d="..." fill="#0000FF"/>
    </g>
    <g class="large">
      <path d="..." fill="#00FF00"/>
    </g>
  </svg>

色の修正

見分けやすくするために色を原色で塗り分けていましたが、もう必要無いので本来の色に戻します。

  <svg width="400" height="198" viewBox="0 0 400 198" fill="none" xmlns="http://www.w3.org/2000/svg">
    <style type="text/css">
      .large {
        display: block;
      }
      .medium {
        display: none;
      }
      .small {
        display: none;
      }
      @media (max-width: 400px) {
        .large {
          display: none;
        }
        .medium {
          display: block;
        }
      }
      @media (max-width: 200px) {
        .medium {
          display: none;
        }
        .small {
          display: block;
        }
      }
    </style>
    <g class="small">
-     <path d="..." fill="#FF0000"/>
+     <path d="..." fill="black"/>
    </g>
    <g class="medium">
-     <path d="..." fill="#0000FF"/>
+     <path d="..." fill="black"/>
    </g>
    <g class="large">
-     <path d="..." fill="#00FF00"/>
+     <path d="..." fill="black"/>
    </g>
  </svg>

完成

ここまでの内容をすべて反映させると下の動画のようになります。
(HTML側に複数imgを設置していないよ、と示したくてコードも表示していましたが、全然見えませんね……)


最後まで読んでくださってありがとうございます!
Twitterでも情報を発信しているので、良かったらフォローお願いします!

  1. コンポーネント化してしまえば良いんですけどね。

26
14
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
26
14

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?