Einführung
In diesem Lab werden wir untersuchen, wie man in React mithilfe des useState-Hooks einen zusammenziehbaren Inhaltskomponenten erstellt. Diese Komponente wird es Benutzern ermöglichen, die Sichtbarkeit des Inhalts durch Klicken auf einen Button umzuschalten, was ein nützliches Werkzeug für die Organisation und Präsentation von Informationen auf einer Webseite ist. Am Ende dieses Labs werden Sie ein besseres Verständnis dafür haben, wie man in React wiederverwendbare Komponenten erstellt, die die Zugänglichkeit und die Benutzererfahrung Ihrer Webanwendungen verbessern.
Zusammenziehbarer Inhalt
In der VM wurden bereits
index.htmlundscript.jsbereitgestellt. Im Allgemeinen müssen Sie nur Code inscript.jsundstyle.csshinzufügen.
Diese Funktion rendert eine zusammenziehbare Komponente mit einem Button, der die Sichtbarkeit ihres Inhalts umschaltet. Hier ist, wie Sie sie verwenden können:
- Verwenden Sie den
useState()-Hook, um dieisCollapsed-Zustandsvariable zu erstellen, die angibt, ob der Inhalt derzeit zusammengelegt oder erweitert ist. Initialisieren Sie es mitcollapsed. - Verwenden Sie das
<button>-Element, um denisCollapsed-Zustand umzuschalten und den über diechildren-Eigenschaft weitergegebenen Inhalt anzuzeigen/auszublenden. - Verwenden Sie
isCollapsed, um der Inhaltscontainer die passende CSS-Klassecollapsedoderexpandedanzuwenden, die seine Erscheinung bestimmt. - Aktualisieren Sie das
aria-expanded-Attribut des Inhaltscontainers basierend auf demisCollapsed-Zustand, um die Komponente für behinderte Benutzer zugänglich zu machen.
Hier ist der für diese Komponente erforderliche CSS-Code:
.collapse-button {
display: block;
width: 100%;
}
.collapse-content.collapsed {
display: none;
}
.collapse-content.expanded {
display: block;
}
Und hier ist der JavaScript-Code:
const Collapse = ({ collapsed, children }) => {
const [isCollapsed, setIsCollapsed] = React.useState(collapsed);
return (
<>
<button
className="collapse-button"
onClick={() => setIsCollapsed(!isCollapsed)}
>
{isCollapsed ? "Anzeigen" : "Verbergen"} Inhalt
</button>
<div
className={`collapse-content ${isCollapsed ? "collapsed" : "expanded"}`}
aria-expanded={isCollapsed}
>
{children}
</div>
</>
);
};
Um diese Komponente zu verwenden, rufen Sie sie einfach mit dem Inhalt auf, den Sie zusammenfalten möchten:
ReactDOM.createRoot(document.getElementById("root")).render(
<Collapse>
<h1>Dies ist eine Zusammenfassung</h1>
<p>Hallo Welt!</p>
</Collapse>
);
Bitte klicken Sie in der unteren rechten Ecke auf 'Go Live', um den Webdienst auf Port 8080 auszuführen. Anschließend können Sie die Registerkarte Web 8080 aktualisieren, um die Webseite anzuschauen.
Zusammenfassung
Herzlichen Glückwunsch! Sie haben das Lab "Zusammenziehbarer Inhalt" abgeschlossen. Sie können in LabEx weitere Labs absolvieren, um Ihre Fähigkeiten zu verbessern.