Einführung
In diesem Lab werden wir untersuchen, wie man ein Schaltflächenkomponente mit React implementiert. Die Schaltflächenkomponente ist ein übliches Benutzeroberflächenelement, das zum Umschalten zwischen zwei Zuständen verwendet wird. Wir werden den useState()-Hook verwenden, um den Zustand der Komponente zu verwalten und unterschiedliche CSS-Klassen basierend auf seinem Zustand anzuwenden. Am Ende dieses Labs werden Sie ein besseres Verständnis dafür haben, wie man wiederverwendbare Benutzeroberflächenkomponenten in React erstellt.
Schaltfläche
In der VM wurden bereits
index.htmlundscript.jsbereitgestellt. Im Allgemeinen müssen Sie nur Code inscript.jsundstyle.csshinzufügen.
Um eine Schaltflächenkomponente zu rendern, folgen Sie diesen Schritten:
- Verwenden Sie den
useState()-Hook, um dieisToggledOn-Zustandsvariable aufdefaultToggledzu initialisieren. - Rendern Sie ein
<input>-Element und binden Sie seinonClick-Ereignis, um dieisToggledOn-Zustandsvariable zu aktualisieren. Wenden Sie die passendeclassNameauf das umgebende<label>-Element an. - Verwenden Sie die folgende CSS, um die Schaltflächenkomponente zu gestalten:
.toggle input[type="checkbox"] {
display: none;
}
.toggle.on {
background-color: green;
}
.toggle.off {
background-color: red;
}
Hier ist der Code:
const Toggle = ({ defaultToggled = false }) => {
const [isToggleOn, setIsToggleOn] = React.useState(defaultToggled);
return (
<label className={isToggleOn ? "toggle on" : "toggle off"}>
<input
type="checkbox"
checked={isToggleOn}
onChange={() => setIsToggleOn(!isToggleOn)}
/>
{isToggleOn ? "ON" : "OFF"}
</label>
);
};
ReactDOM.createRoot(document.getElementById("root")).render(<Toggle />);
Bitte klicken Sie auf 'Go Live' in der unteren rechten Ecke, 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 Schaltflächenlab abgeschlossen. Sie können in LabEx weitere Labs absolvieren, um Ihre Fähigkeiten zu verbessern.