Heim > Web-Frontend > CSS-Tutorial > Warum verhält sich das onerror-Attribut für Bildelemente in allen Browsern inkonsistent?

Warum verhält sich das onerror-Attribut für Bildelemente in allen Browsern inkonsistent?

Linda Hamilton
Freigeben: 2024-11-04 10:22:29
Original
569 Leute haben es durchsucht

Why Does the onerror Attribute for Image Elements Behave Inconsistently Across Browsers?

Verwenden des onerror-Attributs für Bildelemente

In HTML können Sie mit dem onerror-Attribut eine Aktion angeben, die ausgeführt werden soll, wenn ein Bild fehlschlägt laden. Es wurde jedoch beobachtet, dass dieses Attribut in bestimmten Browsern nicht immer wie erwartet funktioniert.

Im bereitgestellten Beispiel, in dem das onerror-Attribut verwendet wird, um die Quelle fehlerhafter Bilder zu ändern, unterscheidet sich das Verhalten je nach Browser . Um dieses Problem zu beheben, ist ein geänderter Ansatz erforderlich.

Die folgenden aktualisierten Codefragmente beheben das Problem in Chrome und Mozilla und wahren gleichzeitig die Kompatibilität mit IE:

<code class="css">.posting-logo-div {
}
.posting-logo-img {
  height: 120px;
  width: 120px;
}
.posting-photo-div {
  height: 5px;
  width: 5px;
  position: relative;
  top: -140px;
  left: 648px;
}
.posting-photo-img {
  height: 240px;
  width: 240px;
}</code>
Nach dem Login kopieren
<code class="html"><div id="image" class="posting-logo-div">
  <img src="invalid_link"
       onerror="this.onerror=null;this.src='https://placeimg.com/200/300/animals';"
   class="posting-logo-img"
  />
</div>
<div id="photo" class="posting-photo-div">
  <img src="invalid_link"
       onerror="this.onerror=null;this.src='https://placeimg.com/200/300/animals';"
       class="posting-photo-img"
  />
</div></code>
Nach dem Login kopieren

Durch Aufheben des onerror-Handler mit this.onerror=null; Bevor wir die Bildquelle ändern, können wir eine Endlosschleife verhindern, die auftreten könnte, wenn auch die Backup-URL ungültig ist.

Eine Live-Demonstration dieses Ansatzes finden Sie unter: http://jsfiddle.net/oLqfxjoz/

Das obige ist der detaillierte Inhalt vonWarum verhält sich das onerror-Attribut für Bildelemente in allen Browsern inkonsistent?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage