React-Hook中使用useEffect清除定時器的實現方法
useEffect
之前我們學習了class組件的聲明周期,那么我們想在函數式組件中做一些聲明周期有關操作能否實現呢?
函數式組件中是沒有生命周期的,所以就可以使用useEffect來替代。我們可以把useEffect看作組件加載、組件更新、組件卸載的三個生命周期方法的組合。
下面我們一起來通過案例學習useEffect的使用:
1.這里需求是寫一個點擊事件讓state累加,并且吧state展示在title上
2.首先要導入React, { useState, useEffect }
3.然后使用 useEffect將state渲染給title
4.最后綁定點擊事件
import React, { useState, useEffect } from 'react' export default function App() { const [state, setstate] = useState(0) useEffect(() => { document.title = `你點擊了${state}次` }) return ( <div> <h1>{state}</h1> <button onClick={e => setstate(state + 1)}>點擊</button> </div> ) }
查看運行效果:
所以我們可以發(fā)現:默認情況下,useEffect會在第一次渲染之后和每次更新之前都會執(zhí)行
基于它的這個特性,我們再來看一個例子:
1.實現的效果是,點擊按鈕能切換狀態(tài)是否顯示page頁面,page頁面的按鈕能夠控制age和money的改變,比較簡單,大家應該都能看懂
import React, { useState, useEffect } from 'react' function Page() { const [age, setage] = useState(18) const [money, setmoney] = useState(1000) useEffect(() => { console.log('我被執(zhí)行了') }) return ( <div> <h1>{age}</h1> <h2>{money}</h2> <button onClick={e => setage(age + 1)}>長大</button> <button onClick={e => setmoney(money + 1000)}>變有錢</button> </div> ) } export default function App() { const [show, setshow] = useState(true) return ( <div> <h1>{show}</h1> <button onClick={e => setshow(!show)}>切換狀態(tài)</button> {show && <Page/>} </div> ) }
我這里在useEffect中進行了打印,下面我們來看看何時會觸發(fā)useEffect
可以看到每次更新的時候都會觸發(fā)useEffect,這里的useEffect還可以傳入參數,例如:
在后面的數組中寫入age和money,實現的效果是一樣的
useEffect(() => { console.log('我被執(zhí)行了') }, [age, money])
但是如果只寫一個:
useEffect(() => { console.log('我被執(zhí)行了') }, [age])
查看結果:
可以看到age狀態(tài)發(fā)生改變時它會被調用,但是money發(fā)生改變,他并不會調用
所以這里數組傳入是依賴項,只有數組中的狀態(tài)發(fā)生了變化,才會去觸發(fā)useEffect執(zhí)行
如果我們想在useEffect中進行請求,也就是只想它觸發(fā)一次,應該怎么做呢:
如下使用空數組即可:
useEffect(() => { console.log('我被執(zhí)行了') }, [])
useEffect清除定時器
先來回顧一下在class組件中如何清除定時器:
如以下代碼,需要在componentWillUnmount生命周期函數中進行定時器的清除操作
export class App extends Component { state = { count: 0 } componentDidMount() { this.timer = setInterval(() => { this.setState({count: this.state.count + 1}) }, 500) } componentWillUnmount() { clearInterval(this.timer) } render() { return ( <div> <h1>{this.state.count}</h1> </div> ) } }
那么使用useEffect該如何去實現呢?
只需要return出去就可以了,看下面代碼
import React, { useState, useEffect } from 'react' export default function App() { const [state, setstate] = useState(0) useEffect(() => { const timer = setInterval(() => { setstate(prev => prev + 1) }, 1000) // 清除定時器 return () => clearInterval(timer) }, []) return ( <div>{state}</div> ) }
最后
本篇文章的講解就到這里啦,主要介紹了useEffect的功能以及使用方法,還有如何使用他清除定時器,如果對你有幫助,點贊關注支持下呀~后續(xù)還會給大家?guī)砀鄡?yōu)質內容
到此這篇關于React-Hook中useEffect詳解(使用useEffect清除定時器)的文章就介紹到這了,更多相關react Hook useEffect清除定時器內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
在React中使用React.createRef:更優(yōu)雅的DOM引用方式
React提供了多種方式來引用DOM元素,其中React.createRef()是一種更為現代、更優(yōu)雅的方式,在這篇文章中,我們將深入了解React.createRef()的應用,以及它為開發(fā)者帶來的便利,感興趣的朋友一起看看吧2024-01-01