react hooks 之 useEffect

useEffect

  • useEffect 可以彌補(bǔ)函數(shù)組件沒(méi)有生命周期的缺點(diǎn)。我們可以在useEffect第一個(gè)參數(shù)回調(diào)函數(shù)中,做一些請(qǐng)求數(shù)據(jù),事件監(jiān)聽(tīng)等操作,第二個(gè)參數(shù)作為 dep 依賴(lài)項(xiàng),當(dāng)依賴(lài)項(xiàng)發(fā)生變化,重新執(zhí)行第一個(gè)函數(shù)。
  • useEffect 看做 componentDidMount ,componentDidUpdatecomponentWillUnmount 這三個(gè)函數(shù)的組合。
  • useEffect 執(zhí)行順序:組件更新掛載完成 => 瀏覽器 DOM 繪制完成 => 執(zhí)行 useEffect 回調(diào)。
  • 在 React 更新 DOM 之后運(yùn)行一些額外的代碼。比如發(fā)送網(wǎng)絡(luò)請(qǐng)求,手動(dòng)變更 DOM,記錄日志,這些都是常見(jiàn)的無(wú)需清除的操作。
import React, { useEffect, useState } from "react";
import './App.css';

function App() {
    let [num1, setNum1] = useState(0);
    let [num2, setNum2] = useState(0);

    const add1 = () =>{
      setNum1(num1+1);
    }
    const add2 = () =>{
      setNum2(num2+1);
    }

  // 實(shí)時(shí)監(jiān)聽(tīng)所有
  // useEffect(()=>{
  //   console.log('num1', num1);
  //   console.log('num2', num2);
  //   console.log('============');
  // })

  // 只在初次渲染時(shí)監(jiān)聽(tīng)
  // useEffect(()=>{
  //   console.log('num1', num1);
  //   console.log('num2', num2);
  //   console.log('============');
  // },[])

  // 實(shí)時(shí)監(jiān)聽(tīng) num1
  useEffect(()=>{
    console.log('num1', num1);
    console.log('num2', num2);
    console.log('============');
  },[num1]);



  return (
      <div className="App">
        <h1 onClick={add1}>num1:{num1}</h1>
        <h1 onClick={add2}>num2:{num2}</h1>
    </div>
  );
}

export default App;

  • useEffect 返一個(gè)函數(shù)用于清除事件監(jiān)聽(tīng)等操作。
import React, { useEffect, useState } from "react";
import './App.css';

/* 定時(shí)器 延時(shí)器等 */
const timer = setInterval(()=>console.log('setInterval'), 1000);

/* 模擬事件監(jiān)聽(tīng)處理函數(shù) */
const handleResize =()=>{
  console.log('handleResize');
}
/* 事件監(jiān)聽(tīng) */
window.addEventListener('resize', handleResize);

function App() {
    let [num1, setNum1] = useState(0);

    const add1 = () =>{
      setNum1(num1+1);
    }

    // num1的值變化時(shí)清除
    useEffect(()=>{
      return function(){
        console.log('num1 值變化了');
        clearInterval(timer);
        window.removeEventListener('resize', handleResize);
      }
    }, [num1]);

    return (
        <div className="App">
          <h1 onClick={add1}>num1:{num1}</h1>
      </div>
    );
}

export default App;
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • React Hook useEffect 就是一個(gè) Effect Hook,給函數(shù)組件增加了操作副作用的能力。它跟...
    FConfidence閱讀 418評(píng)論 0 0
  • 自從Hooks出現(xiàn),函數(shù)式組件(Function Component)的功能在不斷豐富,你很可能已經(jīng)運(yùn)用Hooks...
    tracyXia閱讀 11,586評(píng)論 2 7
  • Hook 是 React 16.8 的新增特性。它可以讓你在不編寫(xiě) class 的情況下使用 state 以及其他...
    mora__閱讀 675評(píng)論 0 0
  • 1、什么是Hooks 在不編寫(xiě) class 的情況下使用 state 以及其他的 React 特性(生命周期) 規(guī)...
    郭仙人不是閑人閱讀 529評(píng)論 0 0
  • useEffect(副作用)通過(guò)一個(gè)參數(shù)來(lái)實(shí)現(xiàn)模擬class組件的componentDidMount、compon...
    林夕_f1e9閱讀 1,456評(píng)論 0 0

友情鏈接更多精彩內(nèi)容