Bertindak balas: Negeri X Keadaan Terbitan

Linda Hamilton
Lepaskan: 2024-09-24 08:30:10
asal
128 orang telah melayarinya

React: State X Derived State

Apakah keadaan terbitan? Fikirkan satu keadaan untuk teks dan kemudian satu lagi untuk teks huruf besar.

Negeri Terbitan

function Foo() {
    const [text, setText] = useState('hello, za warudo!');
    const [uppercaseText, setUppercaseText] = useState(text.toUpperCase());

    useEffect(() => {
        setUppercaseText(text.toUpperCase());
    }, [text])

    ...
}
Salin selepas log masuk

Menyatakan seperti itu adalah gila untuk berfikir bahawa sesiapa sahaja akan melakukan ini… betul? BETUL?

Ya, contoh seperti ini akan menjelaskan bahawa ini salah.

Keburukan Negara Terbitan

  • Disimpan secara berasingan dan tidak selari dengan keadaan sebenar.
  • Pencetus (bergantung) pada pemaparan semula yang tidak perlu.

Bagaimana untuk memfaktorkan semula keadaan terbitan?

Katakan ini pengiraan yang mahal… penyelesaiannya ialah menggunakan useMemo.

function Foo() {
    const [text, setText] = useState('hello, za warudo!');
    const uppercaseText = useMemo(() => text.toUpperCase(), [text]);
    ...
}
Salin selepas log masuk

Bagaimana dengan cepat melihat keadaan yang boleh diperolehi?

Saya telah menghasilkan cara berfikir yang baik yang sepatutnya memudahkan untuk TAHU jika sesuatu negeri itu sepatutnya "keadaan lain" atau hanya harta yang dikira (dihafal atau tidak bergantung pada kes).

function Foo({
    text = 'hello, za warudo!',
    uppercaseText = text.toUpperCase(),
}) {
    ...
}

// Forget react for a moment...
// Would you ever call a function like this?
const text = 'hello, za warudo!';
Foo({
    text,
    uppercaseText: text.toUpperCase(),
});
Salin selepas log masuk

Jika anda menganggap keadaan tersebut sebagai "props", maka ini menjadikannya lebih jelas keadaan yang sepatutnya.

Lupakan React sepenuhnya, fikirkan hanya fungsi:
Adakah anda akan memanggil fungsi dengan pembolehubah dan kemudian pembolehubah lain yang anda boleh kira di dalamnya?

Atas ialah kandungan terperinci Bertindak balas: Negeri X Keadaan Terbitan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:dev.to
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!