キーワード検索48の記事がヒットしました。

鳥に生まれることができなかった人へ

画像を表示させよう

今回はWebページに画像を表示させる方法を学びます。画像の表示は意外とややこしく方法はいくつかありますが、今回はimg要素を使う方法を紹介します。この方法が一番簡単です。

まずは以下のようなindex.htmlを用意します。

index.html
<!DOCTYPE html>
<html lang="ja">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>画像を表示させよう</title>
</head>
<body>

</body>
</html>

そして同じフォルダーにimagesというフォルダーを作成します。ここに表示させたい画像を保存するようにしましょう。

画像を入手

画像が無くては始まりませんから、適当な画像を用意してください。「何でもいいよ」「面倒くさい」という方は、以下の画像を右クリックして、「名前を付けて画像を保存…」を選択し、画像をダウンロードします。先ほど作成したimagesフォルダーに保存しましょう。

sample image

ファイル名は何でもOKです。恐らく、ダウンロードした画像はsample-image.pngというファイル名になっていると思いますが、他の名前を付けたいのであれば変更しても当然OKです。ここではsample-image.pngであるとして進めます。

念のため現在のフォルダー構成を確認しておきます。

image01

img要素

画像を表示させるにはimg要素を使用します。「image」のimgですね、わかりやすいです。

また、src属性に画像ファイルの保存場所をパスで記述することで指定して、画像ファイルを取り込みます。「source」のsrcですね、わかりやすいです。

パスについては前回学習しました。今回も相対パスを使います。imagesフォルダーの中のsample-image.pngを表すためには、src="images/sample-image.png"と記述します。

そしてimgタグは空タグなので、終了タグは存在しません。

具体的にHTMLコードは以下のようになります。

index.html
<body>
  <img src="images/sample-image.png">
</body>

ここで実際にページを確認してみます。

image02

画像が表示されない場合は、パス(つまりフォルダー名やファイル名)が間違っている可能性が高いです。もう一度チェックしてみてください。

alt属性

img要素においてsrc属性は必須です。画像ファイルの在処を示すものですから当たり前ですね。

必須ではないものの記述することが強く推奨されるのがalt属性です。「alternative」のaltです。画像の代わりに使用される、画像を説明する端的な文章を入力します。

alt属性を記述しても通常は画面上に表示されることはありません。alt属性が活躍する状況として、画像が表示されない場合が挙げられます。

src属性の値を変更し、存在しないパスにしてみましょう。src属性自体を消してしまってもOKです。そして、alt属性を用意し、サンプル画像と入力してみましょう。

index.html
<body>
  <img src="noimage" alt="サンプル画像">
</body>

この状態でアクセスすると、画像を示すアイコンとalt属性に記述した文章が表示されていることが分かります。このようなアイコンと文字、見たことありますよね?

image03

画像が表示されない理由は様々です。src属性のパスが間違っていることもそうですし、実際のWebサイトであればネットワークの状況によって画像ファイルの取得が出来なかったり遅れているという状況も当てはまります。ともかく、何かしらトラブルがあった場合に「本当はこんな内容の画像が表示されるんだよ」ということを伝えられるため、alt属性は必ず記述するようにしましょう。

画像をリンクにすることもできる

前回学習したa要素と組み合わせ、画像をリンクにすることもできます。index.html以外にももう一つhtmlファイルを用意してください。ここでは以前作成したabout.htmlを利用します。index.htmlと同じフォルダー内に保存します。

さて思い出してほしいのですが、<a href=""></a>に囲まれた中身が実際のリンクになるんでしたね。今回は画像をリンクにするため、a要素でimg要素を囲えばOKです。

index.html
<body>
  <a href="about.html">
    <img
      src="images/sample-image.png"
      alt="アバウトページへのリンク画像"
    >
  </a>
</body>

再度ページにアクセス、画像をクリックしリンク先のページへ移動できるか確認してください。

リンクにしたところで画像の表示に変化はありません。ただ、画像にマウスポインターを乗せた時の表示には変化があります。ただの画像の時は、ポインターは矢印のまま変化しません。

image04

画像をリンクにした時は、ポインターが手のひらのマークに変化します。

image05

これは画像だからこうなるというわけではなく、文字列をリンクにした場合も同様の変化が起こります。普段インターネットを徘徊されている方ならお馴染みの動作ですね。

画像の大きさはどうやって変更するの?

さて、今は画像の大きさのまま画面上に表示されています。「もっと小さく画像を表示させたい」という場合はどうすればいいのでしょうか。そのサイズの画像を用意するのも手ですが、様々なサイズが必要になると際限がなくなります。

画像の表示サイズはHTMLとCSSで柔軟に変化させることができます。この方法は様々あるのですが、ここではHTMLにおいてimgタグの中でwidth属性やheight属性を指定する方法を紹介します。

まずはwidth属性を指定してみましょう。widthは「ウィッズ」「ウィズ」などと発音し(諸説あり)、横幅を意味する単語です。width属性に500を指定すると、画像の横幅が500pxに変化します。

index.html
<body>
  <img
    src="images/sample-image.png"
    alt="アバウトページへのリンク画像"
    width="500"
  >
</body>

この時、画像の高さはアスペクト比を保つように変化します。width属性で横幅を変化させたからと言って、縦横の比率は変わらないという事ですね。

image06

高さを指定するにはheight属性を指定します。heightは「ハイト」と発音します。height属性に200を指定すると、画像の高さが200pxに変換します。これもwidth指定の時と同じく、アスペクト比を保つ形で画像の横幅が自動的に変化します。

index.html
<body>
  <img
    src="images/sample-image.png"
    alt="アバウトページへのリンク画像"
    height="200"
  >
</body>

image07

width属性とheight属性は指定しないとだめ?

この2つの属性は必須項目ではありません。また、画像のサイズはCSS側で変化させることが多いです。

しかし、レイアウトシフトなるものを防ぐため、これらの属性を指定するのがいいというのが私の考えです。

具体的な数値ですが、画像ファイルの横幅と高さをそのまま記述するのが良いと考えます。ここで画像の横幅と高さを確認する方法を紹介します。

画像ファイルを右クリックして、『プロパティ』を選択します。『詳細』タブを選択すれば『幅』『高さ』という項目があるので、これをwidth属性、height属性に指定すればいいでしょう。

image08

index.html
<body>
  <img
    src="images/sample-image.png"
    alt="サンプル画像"
    width="800"
    height="494"
  >
</body>

まとめ

  • ✅ 画像はimg要素で表示する
  • src属性に画像ファイルのパスを記述する
  • alt属性も必須ではないが記述するべき
  • width属性、height属性も指定するのがおすすめ
  • ✅ 画像の大きさはCSSでも変更できる

これまで長らくHTMLを学習してきましたが、次回からはCSSの学習を始めたいと思います。まだまだ紹介するべきHTMLタグが残っていますので、CSSの学習と同時進行という形で進めていきます。

参考

<img>: 画像埋め込み要素 | MDN

【初心者向け】HTMLで画像にリンクを付ける方法 | CodeCampus

HTMLの画像(imgタグ)の使い方・コンプリートガイド

再確認:画像imgタグにサイズ指定をする事はSEO上重要です

【2020年夏】imgタグにはwidthとheight属性を書くのがいいらしい | Rriver

レスポンシブデザインに於けるwidth, height属性について | The other way round

source要素にwidth/height属性を指定して各画像のアスペクト比の維持とCLSの改善を図る | フロントエンドBlog | ミツエーリンクス

画像による Layout Shift が無くなる Web がやって来る - mizdra’s blog

A more elegant and easier to use solution · Issue #16 · WICG/intrinsicsize-attribute