react实现computed和watch

类组件

1. componentDidUpdate可以实现两者

2. getter方法可以实现computed
get address() {
    const { province, city } = this.state;
    return `${province} ${city}`;
}
getter没有缓存,要加缓存,即属性变化才触发重新计算,需引入额外的memoize包
getAddress = memoize((province, city) => `${province} ${city}`);

get address() {
    return this.getAddress(this.state.province, this.state.city);
}
函数式组件

1. useMemo实现computed
useMemo(() => {
    return `${province}省${city}市`
}, [province, city]);
2. useEffect实现watch
useEffect(() => {
    console.log('province或city发生了变化: ', province, city);
}, [province, city]);
posted @   全玉  阅读(1289)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示