使用 react useEffect 时,我的应用程序崩溃了

eda*_*med 6 reactjs react-hooks

我将类组件更改为功能组件并使用钩子和 useEffect 所以我的应用程序变得非常缓慢并且没有任何错误

import React, { useState, useEffect } from 'react';
import Toolbar from '@material-ui/core/Toolbar';

const FancyToolBar = ({ children }) => {
  const [backGround, togglebackGround] = useState('white');
  const listenScrollEvent = () => {
    if (window.scrollY > 80) {
      togglebackGround('black');
    } else {
      togglebackGround('white');
    }
  };
  useEffect(() => {
    window.addEventListener('scroll', listenScrollEvent);
  });
  const logo = backGround === 'white'
    ? <img src="/images/1.jpg" alt="" style={{ width: '50px !important', height: '50px' }} />
    : <img src="/images/2.png" alt="" style={{ width: '50px !important', height: '50px' }} />;
  return (
    <Toolbar style={{ backgroundColor: backGround }}>
      {logo}
      {children}
    </Toolbar>
  );
};


export default FancyToolBar;
Run Code Online (Sandbox Code Playgroud)

Shu*_*tri 5

您需要解决两件事。

首先:您需要清理您的eventListener.

第二:仅在初始安装时添加事件侦听器,方法[]是将第二个参数添加到 useEffect

useEffect(() => {
    window.addEventListener('scroll', listenScrollEvent);
    return () => {
      window.removeEventListener('scroll', listenScrollEvent);
    }
  }, []);
Run Code Online (Sandbox Code Playgroud)