HTML5 verfügt über ein neues globales Attribut, hiddenmit dem Inhalte ausgeblendet werden können.
<article hidden>
<h2>Article #1</h2>
<p>Lorem ipsum ...</p>
</article>
CSS hat die display:noneRegel, mit der auch Inhalte ausgeblendet werden können.
article { display:none; }
Optisch sind sie identisch. Was ist der semantische Unterschied? Computergestützt?
Welche Richtlinien sollte ich beachten, wenn ich die eine oder andere verwenden soll?
TIA.
BEARBEITEN : Basierend auf den Antworten von @ newtron (unten) habe ich mehr gesucht. Das hiddenAttribut wurde letztes Jahr heiß umkämpft und schaffte es (anscheinend) kaum in die HTML5-Spezifikation. Einige argumentierten, es sei überflüssig und habe keinen Zweck. Soweit ich das beurteilen kann, lautet die endgültige Bewertung wie folgt: Wenn ich nur auf Webbrowser abziele, gibt es keinen Unterschied. (Auf einer Seite wurde sogar behauptet, dass Webbrowser display:nonedas versteckte Attribut implementiert haben.) Wenn ich jedoch die Barrierefreiheit in Betracht ziehe (z. B. erwarte ich möglicherweise, dass meine Inhalte von Bildschirmlesern gelesen werden), gibt es einen Unterschied. Die CSS-Regel display:noneverbirgt möglicherweise meinen Inhalt vor Webbrowsern, aber eine entsprechende Arienregel (z.aria-hidden="false" ) könnte versuchen, es zu lesen. Daher stimme ich jetzt zu, dass die Antwort von @ newtron richtig ist, obwohl sie vielleicht (wohl) nicht so klar ist, wie ich es gerne hätte. Vielen Dank an @newtron für Ihre Hilfe.
hiddenAttribut existiert, aber sicherlich eine gute Frage, da es die Trennung von Struktur und Präsentation zu verletzen scheint.