欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一文帶你搞懂React的函數(shù)組件

 更新時間:2023年06月16日 09:30:05   作者:何遇er  
React中函數(shù)式組件的基本意義是,組件實際上是一個函數(shù),不是類,下面就來給大家介紹一下關(guān)于React中函數(shù)組件的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下

函數(shù)組件與類組件有什么區(qū)別?如果你對 React Hooks 有基本了解,在這里請拋開 React Hooks 回答這個問題。你的答案是函數(shù)組件沒有自己的 state,也沒有與類組件類似的生命周期概念嗎?在本小節(jié)不討論 state 和生命周期,先看一個函數(shù)調(diào)用的示例,代碼如下:

function getName(params: {name: string}) {
    const count = 0
    return params.name + '-' + count
}
getName({name: '何遇'})
getName({name: 'Bella'})

getName 是一個純函數(shù),不產(chǎn)生任何副作用,當(dāng)執(zhí)行結(jié)束,它的執(zhí)行上下文和活動對象會被銷毀,前后兩次調(diào)用互不影響。對于不使用任何 Hooks 的函數(shù)組件而言,它也是純函數(shù),那么函數(shù)組件前后兩次渲染你還能得出與前后兩次調(diào)用 getName 函數(shù)類似的結(jié)論嗎?

要對比函數(shù)組件和類組件的區(qū)別,下面用類組件和函數(shù)組件實現(xiàn)相同的功能,即:在瀏覽器顯示一個按鈕,點擊按鈕調(diào)用 props 中的方法去更新父組件的 state,隔 1s 之后打印 props.count 的值。類組件的代碼如下:

class ClassCom extends React.Component<Props, never> {
    render(): React.ReactNode {
        return (
            <button onClick={this.onClick}>這是類組件:刷新瀏覽器打開開發(fā)者工具再點擊</button>
        )
    }

    onClick = () => {
	 this.props.updateCount()
        // 隔1s之后打印this.props.count的值
        setTimeout(() => {
            console.log(this.props.count)
        }, 1000);
    }
}

函數(shù)組件的代碼如下:

function FuncCom(props: Props) {
    const onClick = () => {
        props.updateCount()
    // 隔1s之后打印props.count的值
        setTimeout(() => {
            console.log(props.count)
        }, 1000);
    }
    return (
        <button onClick={onClick}>這是函數(shù)組件:刷新瀏覽器打開開發(fā)者工具再點擊</button>
    )
}

FuncCom 和 ClassCom 組件的父級相同,代碼如下:

class FuncComVsClassCom extends React.Component<{},State> {
    state: State = {count: 0}
    render(): React.ReactNode {
        return (
            <>
                <FuncCom 
                    count={this.state.count}
                    updateCount={this.updateCount}
                />
                <ClassCom
                    count={this.state.count}
                    updateCount={this.updateCount}
                />
            </>
        )
    }
    updateCount = () => {
        this.setState((prevSate: State) => {
            return {count: prevSate.count + 1}
        })
    }
}

觀察上述代碼可以發(fā)現(xiàn)傳遞給 FuncCom 和 ClassCom 組件的 props 一樣,但在瀏覽器界面上點擊各自的按鈕,開發(fā)者工具打印的結(jié)果不一樣,F(xiàn)uncCom 組件打印的值為 0,ClassCom 組件打印的值為 1。

現(xiàn)在揭曉答案,點擊 FuncCom 和 ClassCom 組件中的按鈕都會使它們的父級重新渲染,從而導(dǎo)致 FuncCom 和 ClassCom 重新渲染。ClassCom 是類組件,它重新渲染不會創(chuàng)建新的組件實例,在 setTimeout 的回調(diào)函數(shù)中 this.props 拿到了最新的值。FuncCom 是函數(shù)組件,它重新渲染會創(chuàng)建新的執(zhí)行環(huán)境和活動變量,所以在其中訪問 props,不論何時拿到的都是調(diào)用 FuncCom 時傳遞給它的參數(shù),該參數(shù)不可變。

FuncCom 和 ClassCom 組件打印出不同的值,原因在于 props 不可變但類組件實例是可變的,訪問 this.props 將始終得到類組件最新的 props。將ClassCom 的 this.props 賦值給一個變量,在 setTimeout 的回調(diào)函數(shù)中,用該變量訪問 count 屬性能讓兩個組件打印出相同的值。

后續(xù)介紹React Hooks時將繼續(xù)介紹函數(shù)組件只得到本次渲染時 props 和 state 的值。

到此這篇關(guān)于一文帶你搞懂React的函數(shù)組件的文章就介紹到這了,更多相關(guān)React函數(shù)組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React中常見的TypeScript定義實戰(zhàn)教程

    React中常見的TypeScript定義實戰(zhàn)教程

    這篇文章主要介紹了React中常見的TypeScript定義實戰(zhàn),本文介紹了Fiber結(jié)構(gòu),F(xiàn)iber的生成過程,調(diào)和過程,以及 render 和 commit 兩大階段,需要的朋友可以參考下
    2022-10-10
  • React Native:react-native-code-push報錯的解決

    React Native:react-native-code-push報錯的解決

    這篇文章主要介紹了React Native:react-native-code-push報錯的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 用React實現(xiàn)一個類 chatGPT 的交互式問答組件的方法詳解

    用React實現(xiàn)一個類 chatGPT 的交互式問答組件的方法詳解

    這篇文章主要給大家詳細(xì)介紹如何用React實現(xiàn)一個類 chatGPT 的交互式問答組件的方法,文中有詳細(xì)的代碼示例,對我們學(xué)習(xí)有一定的幫助,需要的朋友可以參考下
    2023-06-06
  • React報錯Type '() => JSX.Element[]' is not assignable to type FunctionComponent

    React報錯Type '() => JSX.Element[]&apos

    這篇文章主要為大家介紹了React報錯Type '() => JSX.Element[]' is not assignable to type FunctionComponent解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • 淺析React 對state的理解

    淺析React 對state的理解

    state狀態(tài)是組件實例對象身上的狀態(tài),不是組件類本身身上的,是由這個類締造的實例身上的。這篇文章主要介紹了React 對state的理解,需要的朋友可以參考下
    2021-09-09
  • 40行代碼把Vue3的響應(yīng)式集成進(jìn)React做狀態(tài)管理

    40行代碼把Vue3的響應(yīng)式集成進(jìn)React做狀態(tài)管理

    這篇文章主要介紹了40行代碼把Vue3的響應(yīng)式集成進(jìn)React做狀態(tài)管理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • 記錄React使用connect后,ref.current為null問題及解決

    記錄React使用connect后,ref.current為null問題及解決

    記錄React使用connect后,ref.current為null問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • react-router實現(xiàn)跳轉(zhuǎn)傳值的方法示例

    react-router實現(xiàn)跳轉(zhuǎn)傳值的方法示例

    這篇文章主要給大家介紹了關(guān)于react-router實現(xiàn)跳轉(zhuǎn)傳值的相關(guān)資料,文中給出了詳細(xì)的示例代碼,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。
    2017-05-05
  • webpack入門+react環(huán)境配置

    webpack入門+react環(huán)境配置

    webpack是一個前端資源模塊化管理和打包工具,說白了就是方便我們管理自己的常用的一些代碼,比如你開發(fā)中用到sass以及jade同時用到es6,開發(fā)時你不可能改動某個地方就挨個命令去轉(zhuǎn)換再到瀏覽器去看效果,那樣效率是非常低的。所以webpack幫我們省去了那些多余的步驟。
    2017-02-02
  • react之umi配置國際化語言locale的踩坑記錄

    react之umi配置國際化語言locale的踩坑記錄

    這篇文章主要介紹了react之umi配置國際化語言locale的踩坑記錄,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02

最新評論