Rumah >hujung hadapan web >tutorial js >Cangkuk Tersuai dalam Reaksi: Menggunakan Semula Logik Merentas Komponen
A Custom Hook ialah fungsi JavaScript yang membolehkan anda menggunakan semula logik stateful merentas berbilang komponen dalam aplikasi React. Cangkuk tersuai ialah alat berkuasa untuk merangkum logik yang boleh dikongsi antara komponen, memastikan komponen bersih dan menggalakkan kebolehgunaan semula kod.
Cakuk tersuai diawali dengan penggunaan, untuk mengikut konvensyen React dan boleh menggunakan cangkuk lain di dalamnya (seperti useState, useEffect, useContext, dll.).
Cangkuk tersuai memberikan beberapa faedah:
Untuk membuat cangkuk tersuai, ikut langkah berikut:
Berikut ialah contoh mudah cangkuk tersuai yang menguruskan kedudukan tetikus:
import { useState, useEffect } from 'react'; // Custom Hook to track mouse position const useMousePosition = () => { const [position, setPosition] = useState({ x: 0, y: 0 }); useEffect(() => { const updatePosition = (event) => { setPosition({ x: event.clientX, y: event.clientY }); }; // Add event listener for mouse movement window.addEventListener('mousemove', updatePosition); // Clean up the event listener return () => { window.removeEventListener('mousemove', updatePosition); }; }, []); return position; }; export default useMousePosition;
Kini, anda boleh menggunakan cangkuk tersuai ini dalam mana-mana komponen untuk mengakses kedudukan tetikus:
import { useState, useEffect } from 'react'; // Custom Hook to track mouse position const useMousePosition = () => { const [position, setPosition] = useState({ x: 0, y: 0 }); useEffect(() => { const updatePosition = (event) => { setPosition({ x: event.clientX, y: event.clientY }); }; // Add event listener for mouse movement window.addEventListener('mousemove', updatePosition); // Clean up the event listener return () => { window.removeEventListener('mousemove', updatePosition); }; }, []); return position; }; export default useMousePosition;
Anda boleh membuat cangkuk tersuai untuk logik yang lebih kompleks, seperti pengendalian borang.
import React from 'react'; import useMousePosition from './useMousePosition'; const MouseTracker = () => { const position = useMousePosition(); // Using the custom hook return ( <div> <h2>Mouse Position:</h2> <p>X: {position.x}, Y: {position.y}</p> </div> ); }; export default MouseTracker;
Kini, anda boleh menggunakan useFormInput dalam komponen borang:
import { useState } from 'react'; // Custom Hook to handle form input const useFormInput = (initialValue) => { const [value, setValue] = useState(initialValue); const handleChange = (event) => { setValue(event.target.value); }; return { value, onChange: handleChange, }; }; export default useFormInput;
Cakuk tersuai mengikut peraturan yang sama seperti cangkuk React:
Cakuk tersuai juga boleh digunakan untuk mengendalikan kesan sampingan, seperti mengambil data.
import React from 'react'; import useFormInput from './useFormInput'; const MyForm = () => { const nameInput = useFormInput(''); const emailInput = useFormInput(''); const handleSubmit = (event) => { event.preventDefault(); console.log('Name:', nameInput.value); console.log('Email:', emailInput.value); }; return ( <form onSubmit={handleSubmit}> <div> <label>Name:</label> <input type="text" {...nameInput} /> </div> <div> <label>Email:</label> <input type="email" {...emailInput} /> </div> <button type="submit">Submit</button> </form> ); }; export default MyForm;
Begini cara anda boleh menggunakan cangkuk useFetchData dalam komponen:
import { useState, useEffect } from 'react'; // Custom Hook to track mouse position const useMousePosition = () => { const [position, setPosition] = useState({ x: 0, y: 0 }); useEffect(() => { const updatePosition = (event) => { setPosition({ x: event.clientX, y: event.clientY }); }; // Add event listener for mouse movement window.addEventListener('mousemove', updatePosition); // Clean up the event listener return () => { window.removeEventListener('mousemove', updatePosition); }; }, []); return position; }; export default useMousePosition;
Atas ialah kandungan terperinci Cangkuk Tersuai dalam Reaksi: Menggunakan Semula Logik Merentas Komponen. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!