Selektor h3:nth-child(1):contains('a') Ineffektivität
Trotz seiner offensichtlichen Syntax ist der Selektor h3: nth-child(1):contains('a') erfüllt seinen Zweck nicht Funktion.
Unter der Haube
Bei weiterer Untersuchung stellt sich heraus, dass h3:nth-child(1) korrekt auf das erste h3-Element innerhalb seines übergeordneten Containers abzielt. Allerdings erzeugt h3:nth-child(1):contains('a') keine Ergebnisse, da der :contains()-Selektor, der ursprünglich als CSS3-Funktion gedacht war, in der CSS-Spezifikation weggelassen wurde.
: enthält() wurde entwickelt, um Elemente zu finden, die ein bestimmtes Textmuster enthalten. Leider stellte die Funktionsweise eine Herausforderung für die Browserleistung dar und führte zu Problemen mit der Überauswahl. Beispielsweise würde der Abgleich eines Elements mit :contains() auch alle seine Vorgänger abgleichen, was bei Kombination mit universellen Selektoren oder bestimmten Stileigenschaften möglicherweise zu unerwartetem Verhalten führen würde.
Alternative Ansätze
Aufgrund des Fehlens einer geeigneten CSS-Selektor-Alternative sind alternative Methoden erforderlich, um das gewünschte Ergebnis zu erzielen. Sie können die HTML-Struktur ändern oder die jQuery-Implementierung von :contains() verwenden:
Überlegungen zu jQuery oder Selenium RC
Für Benutzer von jQuery und Selenium RC: :contains() ist in der Sizzle-Auswahl-Engine implementiert und bietet ähnliche Funktionen wie die CSS3-Spezifikation. Es wird jedoch empfohlen, diesen Selektor mit Bedacht zu verwenden, um unerwartete Auswahlen zu vermeiden.
Eine Verfeinerung
Zuletzt kann h3:nth-child(1) durch h3 ersetzt werden :first-child für verbesserte Browserkompatibilität als CSS2-Selektor.
Das obige ist der detaillierte Inhalt vonWarum funktioniert „h3:nth-child(1):contains(\'a\')' nicht wie erwartet?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!