+1 امتیاز
قبل در برنامه نویسی توسط (308 امتیاز)
برچسب گذاری دوباره قبل توسط

در مثال زیر برای جلوگیری از re-render مقادیر تصادفی در کامپوننت Child از useCallback استفاده کردم ولی هر بار با کلیک بر روی buttom یک مقدار تصادفی برای من نمایش داده می شود در حالی که dependency های useCallback همیشه مقداری ثابت می باشد لطفا راهنمایی کنید

import React, {useCallback, useEffect, useMemo, useState} from 'react';

const TestCallback = () => {

    const [num, setNum] = useState(0)
    const color =  5
    const Child = ({colorId}) => {
        const [randomNum, setRandom] = useState(0)

        const setRandomNum = useCallback(() => {
            const min = 1;
            const max = 100;
            const rand = min + Math.random() * (max - min);
            setRandom(rand)
        }, [colorId])

        useEffect(() => {
            setRandomNum()
        }, [setRandomNum])

        return (
            <>
                random number is {randomNum}
            </>
        )
    }

    return (
        <>
            <div style={{display: "flex", justifyContent: "center", flexDirection: "column", padding: "20%"}}>
                <button onClick={() => setNum(num + 1)}>click</button>
                <br/>
                {num}
                <br/>
                <Child colorId={color}/>
            </div>
        </>
    )
    
}


export default TestCallback

 

سوالات مشابه

+1 امتیاز
0 پاسخ 567 بازدید
0 امتیاز
1 پاسخ 34.0هزار بازدید
+1 امتیاز
1 پاسخ 338 بازدید
0 امتیاز
0 پاسخ 437 بازدید
سوال شده 6 سال قبل در برنامه نویسی توسط MJ1991 (10 امتیاز)
0 امتیاز
1 پاسخ 817 بازدید
0 امتیاز
1 پاسخ 461 بازدید
...