Heim >Web-Frontend >CSS-Tutorial >Können sich CSS-Hover-Effekte auf nicht zielgerichtete Elemente auswirken?

Können sich CSS-Hover-Effekte auf nicht zielgerichtete Elemente auswirken?

Linda Hamilton
Linda HamiltonOriginal
2024-12-11 01:20:09260Durchsuche

Can CSS Hover Effects Affect Non-Targeted Elements?

Können sich CSS-Hover-Effekte auf verschiedene Elemente erstrecken?

In CSS ist es nicht direkt möglich, Hover-Effekte auf ein Element anzuwenden, das an ein anderes Element angrenzt oder in diesem verschachtelt ist. Dies bedeutet, dass der Effekt auf das Element beschränkt bleibt, auf das er angewendet wird, und Sie ihn nicht verwenden können, um andere Elemente zu beeinflussen.

Nachkommen- und benachbarte Geschwistereffekte

Es gibt jedoch zwei Ausnahmen von dieser Regel bei Verwendung des benachbarten Geschwisterselektors ( ) oder des Nachkommenselektors (>):

  • Benachbarte Geschwister: Wenn zwei Elemente benachbarte Geschwister sind (direkt hintereinander im HTML-Code erscheinen), können Sie einen Effekt auf ein Element basierend anwenden über den Schwebezustand des anderen mithilfe des benachbarten Geschwisterselektors. Zum Beispiel:
#first-sibling:hover + #second-sibling {
  opacity: 0.3;
}
  • Nachkommen: Ebenso können Sie, wenn ein Element ein Nachkomme eines anderen Elements ist (im Inneren verschachtelt), einen Effekt auf den Nachkommen anwenden auf dem Schwebezustand des übergeordneten Elements mithilfe des Nachkommenselektors. Zum Beispiel:
#parent-element:hover #child-element {
  opacity: 0.3;
}

Lösung Ihres Problems

In Ihrem konkreten Beispiel möchten Sie die Deckkraft eines Elements namens #thisElement ändern, wenn der Benutzer mit der Maus über ein Bild fährt Klasse von „img.“ Allerdings können Sie #thisElement nicht direkt mit CSS-Hover-Effekten auf „img“ ansprechen. Stattdessen können Sie Folgendes in Betracht ziehen:

  1. Benachbarte Geschwister verwenden: Wenn #thisElement das nächste benachbarte Geschwister des Bildes danach im HTML ist, können Sie Folgendes verwenden:
.img:hover + #thisElement {
  opacity: 0.3;
}
  1. Verwendung von Nachkommen: Wenn #thisElement ist Im Bildcontainer verschachtelt können Sie Folgendes verwenden:
.img-container:hover #thisElement {
  opacity: 0.3;
}

Das obige ist der detaillierte Inhalt vonKönnen sich CSS-Hover-Effekte auf nicht zielgerichtete Elemente auswirken?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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