亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

React-Hook中使用useEffect清除定時器的實現方法

 更新時間:2022年11月03日 11:25:41   作者:北海的大魚  
這篇文章主要介紹了React-Hook中useEffect詳解(使用useEffect清除定時器),主要介紹了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中使用React.createRef:更優(yōu)雅的DOM引用方式

    React提供了多種方式來引用DOM元素,其中React.createRef()是一種更為現代、更優(yōu)雅的方式,在這篇文章中,我們將深入了解React.createRef()的應用,以及它為開發(fā)者帶來的便利,感興趣的朋友一起看看吧
    2024-01-01
  • react-native滑動吸頂效果的實現過程

    react-native滑動吸頂效果的實現過程

    這篇文章主要給大家介紹了關于react-native滑動吸頂效果的實現方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用react-native具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-06-06
  • 淺談React-router v6 實現登錄驗證流程

    淺談React-router v6 實現登錄驗證流程

    本文主要介紹了React-router v6 實現登錄驗證流程,主要介紹了公共頁面、受保護頁面和登錄頁面,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05
  • 詳解React setState數據更新機制

    詳解React setState數據更新機制

    這篇文章主要介紹了React setState數據更新機制的相關資料,幫助大家更好的理解和學習使用React框架,感興趣的朋友可以了解下
    2021-04-04
  • React團隊測試并發(fā)特性詳解

    React團隊測試并發(fā)特性詳解

    這篇文章主要為大家介紹了React團隊測試并發(fā)特性詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 使用react-color實現前端取色器的方法

    使用react-color實現前端取色器的方法

    本文通過代碼給大家介紹了使用react-color實現前端取色器的方法,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2021-11-11
  • react循環(huán)數據(列表)的實現

    react循環(huán)數據(列表)的實現

    這篇文章主要介紹了react循環(huán)數據的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • 一文帶你搞懂React的函數組件

    一文帶你搞懂React的函數組件

    React中函數式組件的基本意義是,組件實際上是一個函數,不是類,下面就來給大家介紹一下關于React中函數組件的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-06-06
  • React組件之間的通信的實例代碼

    React組件之間的通信的實例代碼

    本篇文章主要介紹了React組件間通信的實例代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 探討JWT身份校驗與React-router無縫集成

    探討JWT身份校驗與React-router無縫集成

    這篇文章主要為大家介紹了JWT身份校驗與React-router無縫集成的探討解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06

最新評論