react useEffect中removeEventListener没生效问题解决

在useEffect中写入window.removeEventListener没有生效,代码如下

javascript 复制代码
useEffect(() => {
  const handleResize = () => {
  	console.log(window.innerWidth, window.innerHeight);
  };
  window.addEventListener('resize', handleResize);
  return () => {
    window.removeEventListener('resize', handleResize);
  };
}, [);

没生效原因:

在 removeEventListener 中所传递回的调函数需要与 addEventListener 中的保持一致,而在react中,因为视图更新所产生的更改,导致在return时所传递的函数是最新创建的函数,而不是在addEventListener中所传递的,简单来说就是react的更新机制所导致的引用问题。

解决方法:

使用useCallback来缓存一个函数,避免在每次渲染时重新创建这个函数。

也可以用useRef定义一个函数,确保函数在重新渲染是不被重新创建。

javascript 复制代码
const handleResize = useCallback(() => {
  console.log(window.innerWidth, window.innerHeight);
}, []);
 
useEffect(() => {
  window.addEventListener('resize', handleResize);
  return () => {
    window.removeEventListener('resize', handleResize);
  };
}, [);
相关推荐
cch891820 小时前
常见布局实现详解(Flex 实战版)
前端·javascript·css
telllong20 小时前
Chrome DevTools Protocol:浏览器自动化入门
前端·自动化·chrome devtools
吴声子夜歌20 小时前
Node.js——npm包管理器
前端·npm·node.js
小码哥_常20 小时前
告别启动页“翻车”!Android最新SplashScreen方案全解析
前端
We་ct20 小时前
LeetCode 373. 查找和最小的 K 对数字:题解+代码详解
前端·算法·leetcode·typescript·二分·
薛一半20 小时前
React组件通信初识
前端·react.js·前端框架
aesthetician20 小时前
Tanstack Start:路由魔法与前后端一体化的前端新星!✨
前端
C澒1 天前
微前端容器标准化:容器标准化能力的 “配置化+ 插件化”
前端·架构
anOnion1 天前
构建无障碍组件之Carousel Pattern
前端·html·交互设计
ssshooter1 天前
Tauri 2 iOS 开发避坑指南:文件保存、Dialog 和 Documents 目录的那些坑
前端·后端·ios