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的自定义函数使用

相关推荐
我叫张小白。5 分钟前
Vue3 Hooks:逻辑复用的解决方案
前端·javascript·vue.js·前端框架·vue
IT·小灰灰12 分钟前
深度解析重排序AI模型:基于硅基流动API调用多语言重排序AI实战指南
java·大数据·javascript·人工智能·python·数据挖掘·php
我叫张小白。16 分钟前
Vue3 Props 的使用:组件间数据传递的桥梁
前端·javascript·vue.js·vue3
J***793927 分钟前
前端在移动端中的React Native Windows
前端·react native·react.js
前端程序猿i29 分钟前
前端判断数据类型的所有方式详解
开发语言·前端·javascript
我也爱吃馄饨33 分钟前
前端视角下的浏览器LNA问题
前端·javascript·chrome
何以解忧,唯有..42 分钟前
Vue 列表渲染
前端·javascript·vue.js
g***557542 分钟前
TypeScript 与后端开发Node.js
javascript·typescript·node.js
前端程序猿i1 小时前
彻底搞懂防抖(Debounce)与节流(Throttle):源码实现与应用场景
开发语言·前端·javascript·vue.js·ecmascript
pandarking1 小时前
[CTF]攻防世界:ics-05
开发语言·javascript·web安全·网络安全·ecmascript