Einführung
In diesem Lab werden wir lernen, wie man den useClickOutside-Hook in React verwendet, um Klickereignisse außerhalb eines bestimmten Komponenten zu behandeln. Dieser benutzerdefinierte Hook ermöglicht es uns, einfach zu erkennen, wenn ein Benutzer außerhalb eines bestimmten Komponenten klickt, und eine Aktion aufgrund dieses Ereignisses auszuführen. Am Ende des Labs werden Sie ein besseres Verständnis dafür haben, wie man diesen Hook verwendet, um in Ihren React-Anwendungen interaktivere und nutzerfreundlichere Komponenten zu erstellen.
React useClickOutside-Hook
In der VM wurden bereits
index.htmlundscript.jsbereitgestellt. Im Allgemeinen müssen Sie nur Code inscript.jsundstyle.csshinzufügen.
Dieser Code behandelt das Ereignis, außerhalb eines umfassten Komponenten zu klicken. Er funktioniert, indem ein benutzerdefinierter Hook erstellt wird, der eine ref und einen callback für das Behandeln des click-Ereignisses übernimmt. Der useEffect()-Hook wird verwendet, um das click-Ereignis hinzuzufügen und aufzuräumen, während der useRef()-Hook verwendet wird, um eine ref für die Klickkomponente zu erstellen und an den useClickOutside-Hook zu übergeben.
const useClickOutside = (ref, callback) => {
const handleClick = (e) => {
if (ref.current && !ref.current.contains(e.target)) {
callback();
}
};
React.useEffect(() => {
document.addEventListener("click", handleClick);
return () => {
document.removeEventListener("click", handleClick);
};
});
};
const ClickBox = ({ onClickOutside }) => {
const clickRef = React.useRef();
useClickOutside(clickRef, onClickOutside);
return (
<div
className="click-box"
ref={clickRef}
style={{
border: "2px durchgezogener orangefarben",
Höhe: 200,
Breite: 400,
display: "flex",
justifyContent: "center",
alignItems: "center"
}}
>
<p>Klicken Sie außerhalb dieses Elements</p>
</div>
);
};
ReactDOM.createRoot(document.getElementById("root")).render(
<ClickBox => alert("außerhalb klicken")} />
);
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 React useClickOutside-Hook-Lab abgeschlossen. Sie können in LabEx weitere Labs absolvieren, um Ihre Fähigkeiten zu verbessern.