ホームページ > ウェブフロントエンド > フロントエンドQ&A > HTML で画像が繰り返し表示されるのを防ぐ方法

HTML で画像が繰り返し表示されるのを防ぐ方法

PHPz
リリース: 2023-04-25 14:37:40
オリジナル
7773 人が閲覧しました

Web デザインでは、ページ上に複数の画像を表示する必要があることがよくありますが、場合によっては、これらの画像が繰り返し表示されないようにする必要があります。この場合、HTML のいくつかの属性とテクニックを使用してこれを実現できます。この記事ではHTMLで画像を繰り返し表示させないようにする方法を紹介します。

1. CSS の背景属性を使用する

HTML では、CSS スタイルを使用して要素の背景画像を設定できます。また、background-repeat 属性を使用して、背景画像の繰り返し方法を制御します。 no-repeat に設定すると、背景画像が繰り返されない効果を得ることができます。

たとえば、次の CSS スタイルでは、div 要素の背景画像を「myimage.jpg」に設定し、繰り返し表示しないようにできます。

div {
background-image: url ( myimage.jpg);
background-repeat: no-repeat;
}

2. HTML img タグの onerror 属性を使用します

HTML では、次のように使用できます。 imgタグで画像を表示します。場合によっては、画像が存在しない、または読み込めないという状況が発生することがあります。この時点で、onerror 属性を使用して代替画像アドレスを設定し、ページ画像が繰り返されないようにすることができます。

たとえば、次の img タグは、誤った「image.jpg」がバックアップ イメージ「backup.jpg」を指す可能性があります:

3. JavaScript を使用して実装する

将来さらに複雑なロジックが必要になった場合、HTML と CSS では対応できなくなります。私たちのニーズを満たすために。このとき、JavaScript を使用して画像を動的に読み込んで表示することで、より柔軟な非繰り返し表示を実現できます。

たとえば、次の JavaScript コードは、まず、表示する必要があるすべての画像アドレスを含む配列を作成します。次に、配列をループして毎回画像アドレスを選択し、すでに表示されている画像アドレスの配列と比較して、重複がないことを確認します。最後に、選択した画像アドレスが表示された画像配列に追加され、画像が読み込まれて表示されます。

var imgArray = ['image1.jpg', 'image2.jpg', 'image3.jpg', 'image4.jpg', 'image5.jpg'];
vardisplayedImgs = [];

関数 displayImgRandomly() {
do {

var imgIndex = Math.floor(Math.random() * imgArray.length);
var imgSrc = imgArray[imgIndex];
ログイン後にコピー

} while (displayedImgs.indexOf(imgSrc) !== -1);

displayedImgs.push(imgSrc) );
var imgElement = document.createElement('img');
imgElement.src = imgSrc;
document.body.appendChild(imgElement);
}

上記どちらの方法も、画像を繰り返さない表示を実現する簡単かつ効果的な方法です。具体的な実装は、ニーズと実際の状況によって異なります。基本的な HTML および CSS 属性、img タグの onerror 属性、および JavaScript の柔軟な機能を使用することで、効率的で美しい繰り返しのない画像表示効果を実現し、Web デザインに視覚的な魅力と興味を加えることができます。

以上がHTML で画像が繰り返し表示されるのを防ぐ方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート