0%

Programmingプログラミングナレッジ

Posted:2019.06.10

javascriptを使って画像のリンク切れに一括で代替画像を表示させる

タイトルの通りなのですが、記事のアーカイブなどでサムネイル画像がない場合に代替画像を表示させるケースもあるかと思います。そんな時にjavascriptを使ってフロント側で代替画像に差し替えたい時に使えるテクニックです。

 

単純なコードになりますがサンプルを見ていきます。ちなみにですが、あらかじめ代替画像を用意しておきましょう。まずは対象の画像が1つだけの場合はこんな感じになります。

// HTML
<img src="../example.jpg" alt="画像">

// javascript(ES6)
const image = document.querySelector('img');
image.addEventListener('error',() => {
 image.setAttribute('src', '../no-image.jpg');
});

 

シンプルですが、まずは画像要素を取得して、エラーイベントのコールバック関数内で、対象の画像ソースURLを代替画像のものに差し替えています。また対象の画像が複数ある場合にはこのような形にします。

// HTML
<img src="../example-01.jpg" alt="画像">
<img src="../example-02.jpg" alt="画像">
<img src="../example-03.jpg" alt="画像">
<img src="../example-04.jpg" alt="画像">

// javascript(ES6)
const images = document.querySelectorAll('img');
images.forEach((image) => {
 image.addEventListener('error',() => {
  image.setAttribute('src', '../no-image.jpg');
 });
});

 

ほとんど同じですが、対象の要素が複数の場合は、すべての要素を取得する必要があります。そしてforEachで各要素ごとにチェックしていきます。

 


 

いかがでしょうか、メディアサイトやブログサイトの構築で使える場面がありそうですね。WordPressでは独自の関数が用意されていますが、javascriptで代替する必要がある場合にはこのような対応ができます。

author
この記事を書いた人オガワ シンヤ
FacebookTwitter

DesignSupply.代表 / ディレクター・ウェブデザイナー・フロントエンドエンジニアをやっています。「ウェブとデザインでヒト・モノ・サービスを繋げ新しい価値を生み出す」をコンセプトに日々奮闘中!制作中はチョコレートが欠かせない三十路Webクリエイター。

制作のご依頼やお問い合わせ・パートナー業務提携のご相談はこちら

デザインやウェブ制作についてのご依頼やご相談、その他お問い合わせなどもお気軽にご連絡ください。フットワークの軽さやレスポンスの早さ、また豊富な経験や知識、技術を活かした対応力といったフリーランスクリエイターの強みでクライアント様、パートナー企業様のお力になります。デザインからコーディングやWordPress実装といったウェブサイト構築はもちろん、写真撮影や動画編集、コンテンツ制作からサイト運用サポートまで一括してお任せください。

ホームページ制作のご検討やウェブ運用でお悩みの経営者様や企業のウェブ担当者様をはじめ、個人で店舗を営んでいらっしゃるオーナー様、フリーで活動されているビジネスオーナー様はもちろんのこと、リソース不足でお困りの制作会社様、またクリエイターをお探しの代理店様も大歓迎です。

コンタクトをご希望の方はお手数ですが、下記よりお問い合わせフォームのページへアクセスしていただき、必要事項を入力の上メッセージを送信してください。確認でき次第すぐに折り返しご連絡致します。

こんな記事も読まれています

コメントもお気軽にどうぞ

記事に関するご質問やご意見などありましたら下記のコメントフォームよりお気軽に投稿ください。なおメールアドレスは公開されませんのでご安心ください。また、* が付いている欄は必須項目となります。

内容に問題なければ、下記の「コメントを送信する」ボタンを押してください。

CAPTCHA


ページトップへ
大阪市天王寺区のホームページ制作デザイン事務所(SOHO)DesignSupply.【デザインサプライ】