采纳答案成功!
向帮助你的同学说点啥吧!感谢那些助人为乐的人
为什么第二个参数要写counterRef,这个counterRef不是一直不会变化吗
你好同学,你说的没错,正常的话,ref是不会变的,一直指向同一个对象。依然把它传递给useCallback的原因是,让useCallback的逻辑与变量counterRef的逻辑解耦。
意思就是对于useCallback的意义是:我不管counterRef会不会变,反正我依赖了它,为了我能正常运行,我必须把它声明出来。
你也可以这样理解,万一counterRef会变化,那么useCallback是不会受到影响的,这就是解耦合的意义所在,比如
const oneRef = useRef(); const twoRef = useRef(); const counterRef = <somecondition> ? oneRef : twoRef;
这样的话,counterRef就是会变化的了。尽管让它变化,我们useCallback不需要改动代码。
祝您学习愉快!
非常感谢!谢谢老师
登录后可查看更多问答,登录/注册
"快手"大神教你制作堪比原生APP体验的PWA应用,进阶高级开发
1.0k 8
1.2k 7
1.4k 7
1.3k 6
1.1k 5