react memo判断刷新机制 自定义的比较函数 避免重复渲染

需求:


1. 需要在courseList参数变化时重新渲染组件。
2. 需要在currentWeekNumber参数 等于我指定值才重新渲染组件。
3.以上2个条件同时满足。

遇到的坑

一开始实现了我上面指定的问题需要的函数,后面发现怎么都刷新不了,经过深入观察发现memo在第一次成功渲染后,
之后arePropsEqual函数一直都返回为true 导致Swiper参数
current={currentWeekNumber}
一直处于初始化值
,导致后续当我更新currentWeekNumber的值的时候发现CourseListELement组件根本更新不了(因为后续我触发给swiper参数current的值就是初始值) 明明自定义的比较函数arePropsEqual 一直在返回false 通知CourseListELement组件重新渲染 调试才发现swiper的参数从一开始初始化后一直没有更新

解决方法


给swiper组件添加一个随机key 这样在比较函数arePropsEqual返回false通知更新的时候 swiper才会重新更新,不然没有key的干扰swiper所有参数会一直处于初始化值的状态

注意! key={Math.random()} 不能随便乱用 切换页面会导致当前用key的组件一直重新渲染 非常耗运行资源。建议配合memo的自定义函数使用

相关推荐
王同学QaQ11 小时前
Vue3对接UE,通过MQTT完成通讯
javascript·vue.js
小仙女喂得猪11 小时前
2025 Android原生开发者角度的React/ReactNative 笔记整理
react native·react.js
程序员鱼皮12 小时前
刚刚 Java 25 炸裂发布!让 Java 再次伟大
java·javascript·计算机·程序员·编程·开发·代码
Asort12 小时前
JavaScript 从零开始(五):运算符和表达式——从零开始掌握算术、比较与逻辑运算
前端·javascript
一枚前端小能手12 小时前
🚀 缓存用错了网站更慢?前端缓存策略的5个致命误区
前端·javascript
艾小码12 小时前
为什么你的页面会闪烁?useLayoutEffect和useEffect的区别藏在这里!
前端·javascript·react.js
艾小码12 小时前
告别Vue混入的坑!Composition API让我效率翻倍的3个秘密
前端·javascript·vue.js
骑自行车的码农12 小时前
【React用到的一些算法】游标和栈
算法·react.js
小高00712 小时前
🔍说说对React的理解?有哪些特性?
前端·javascript·react.js
烛阴12 小时前
【TS 设计模式完全指南】懒加载、缓存与权限控制:代理模式在 TypeScript 中的三大妙用
javascript·设计模式·typescript