Dokumentasi ini menggariskan pendekatan komprehensif untuk menstruktur dan mengurus aplikasi React menggunakan set alat dan amalan terbaik yang dipilih susun. Dengan mematuhi garis panduan ini, anda boleh membuat aplikasi berskala, boleh diselenggara dan cekap.
Zustand:
import create from 'zustand'; const useStore = create((set) => ({ count: 0, increment: () => set((state) => ({ count: state.count + 1 })), }));
Pertanyaan Reaksi:
import { useQuery } from 'react-query'; const fetchUsers = async () => { const response = await fetch('https://api.example.com/users'); return response.json(); }; const UsersList = () => { const { isLoading, isError, data, error } = useQuery('users', fetchUsers); if (isLoading) return <div>Loading...</div>; if (isError) return <div>Error: {error.message}</div>; return ( <ul> {data.map((user) => ( <li key={user.id}>{user.name}</li> ))} </ul> ); };
Mutasi:
import { useMutation } from 'react-query'; const createUser = async (userData) => { const response = await fetch('https://api.example.com/users', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify(userData), }); return response.json(); }; const CreateUserForm = () => { const [createUserMutation] = useMutation(createUser); const handleSubmit = (userData) => { createUserMutation(userData) .then(() => { // Handle success }) .catch((error) => { // Handle error }); }; return ( <form onSubmit={handleSubmit}> {/* Form fields */} <button type="submit">Create User</button> </form> ); };
Jadual TanStack:
import { useTable } from 'tanstack/react-table'; const columns = [ { header: 'Name', accessor: 'name' }, { header: 'Email', accessor: 'email' }, ]; const data = [ { name: 'John Doe', email: 'john@example.com' }, // ... ]; const TableComponent = () => { const { getTableProps, getTableBodyProps, headerGroups, rows } = useTable({ columns, data, }); return ( <table {...getTableProps()}> <thead> {headerGroups.map((headerGroup) => ( <tr {...headerGroup.getHeaderGroupProps()}> {headerGroup.headers.map((column) => ( <th {...column.getHeaderProps()}>{column.render('Header')}</th> ))} </tr> ))} </thead> <tbody {...getTableBodyProps()}> {rows.map((row) => ( <tr {...row.getRowProps()}> {row.cells.map((cell) => ( <td {...cell.getCellProps()}>{cell.render('Cell')}</td> ))} </tr> ))} </tbody> </table> ); };
UI Radix:
import { Menu } from '@radix-ui/react-menu'; const MenuComponent = () => { return ( <Menu> <Menu.Button>Open Menu</Menu.Button> <Menu.Items> <Menu.Item>Item 1</Menu.Item> <Menu.Item>Item 2</Menu.Item> </Menu.Items> </Menu> ); };
CSS Tailwind:
import create from 'zustand'; const useStore = create((set) => ({ count: 0, increment: () => set((state) => ({ count: state.count + 1 })), }));
Formik dengan Yup:
import { useQuery } from 'react-query'; const fetchUsers = async () => { const response = await fetch('https://api.example.com/users'); return response.json(); }; const UsersList = () => { const { isLoading, isError, data, error } = useQuery('users', fetchUsers); if (isLoading) return <div>Loading...</div>; if (isError) return <div>Error: {error.message}</div>; return ( <ul> {data.map((user) => ( <li key={user.id}>{user.name}</li> ))} </ul> ); };
src/
├── komponen/
│ ├── Butang.jsx
│ ├── Input.jsx
│ └── ...
├── halaman/
│ ├── Home.jsx
│ │ komponen/
│ │ ├── Hero.jsx
│ │ └── ...
│ ├── About.jsx
│ └── ...
├── lib/
│ ├── utils.js
│ └── ...
├── tindakan/
│ ├── api.js
│ └── ...
├── kedai/
│ ├── counterStore.js
│ └── ...
Dengan mengikuti garis panduan ini dan menggunakan alatan yang disyorkan, anda boleh membina aplikasi React yang teguh, berskala dan boleh diselenggara. Pendekatan ini menggalakkan organisasi kod, kebolehgunaan semula dan pengurusan negeri yang cekap, menghasilkan pengalaman pembangunan yang lebih baik dan perisian berkualiti tinggi.
Atas ialah kandungan terperinci React Toolset untuk Pengurusan Kod Cekap. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!