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

淺談React組件props默認(rèn)值的設(shè)置

 更新時間:2023年04月26日 09:24:50   作者:Jou24  
本文主要介紹了淺談React組件props默認(rèn)值的設(shè)置,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

在編寫react組件的時候,為了兼容一些分支邏輯,我們經(jīng)常會給組件的props設(shè)置一些默認(rèn)值,但是有些默認(rèn)值的寫法會導(dǎo)致一些潛在的問題,比如無法推斷類型,本文將對幾種設(shè)置默認(rèn)值的寫法進行分析,總結(jié)其優(yōu)劣。

解構(gòu)props時設(shè)置默認(rèn)值

interface IProps {
? name: string;
? age?: number;
}

const DefaultProps = (props: IProps) => {
? const { age = 10, name } = props;
? console.log(age + 10);  

? return <div />;
};

這種情況應(yīng)該是我們經(jīng)常會寫的一種方式,在解構(gòu)props時對可選類型設(shè)置默認(rèn)值,在hook組件中這種方法很簡潔,但是在class組件中,凡是用到這些參數(shù)的方法,我們都需要設(shè)置一次默認(rèn)值,組件復(fù)雜度比較高的時候,這樣寫就比較容易出錯。

interface IProps {
? name: string;
? age?: number;
}
class DefaultProps extends Component<IProps, {}> {
? func1() {
? ? const { age = 10, name } = this.props;
? ? //...
? }

? func2() {
? ? const { age = 10, name } = this.props;
? ? //...
? }  

? render() {
? ? return <div />;
? }
}

所以解構(gòu)時設(shè)置默認(rèn)值推薦在hook組件中使用,不推薦在class組件中使用

使用defaultProps

React的組件有一個屬性defaultProps,我們可以通過這個屬性來給組件設(shè)置默認(rèn)參數(shù)。

比如類組件

interface IProps {
? name: string;
? age?: number;
}
class DefaultProps extends Component<IProps, {}> {
? defaultProps = {
? ? age: 20,
? };  
  
  func1() {
? ? const { age, name } = this.props;
? }

? func2() {
? ? const { age, name } = this.props;
? }

? render() {
? ? const { age, name } = this.props;
    console.log(age); ?//20
? ? return <div />;
? }
}

這樣可以避免第一種類組件設(shè)置默認(rèn)值時,需要在每個地方都單獨設(shè)置的冗余情況,但是也帶來了新的弊端,那就是即使設(shè)置了默認(rèn)值,在使用的時候也不能推斷出準(zhǔn)確的類型,依然會提示變量有undefined的風(fēng)險

圖片.png

所以,如果需要更準(zhǔn)確的類型推斷,這里還需要對類型進行額外的處理.

進行額外的類型校驗

因為賦了默認(rèn)值,我們希望能得到更準(zhǔn)確的類型推斷,所以我們可以將默認(rèn)值的類型單獨抽離,再合并到Props的類型中,以達到更好的類型推斷.

interface IProps {
? name: string;
? age?: number;
}
class DefaultProps extends Component<Required<IProps>, {}> {
? defaultProps: Partial<IProps> = {
? ? age: 20,
? };
? render() {
? ? const { age } = this.props;
? ? console.log(age);
? ? return <div />;
? }
}

這里我們將所有屬性全部設(shè)置成可選,然后根據(jù)需要設(shè)置默認(rèn)值,在初始化的時候?qū)rops設(shè)置為Required這樣就能在使用時準(zhǔn)確推斷類型。

圖片.png

值得注意的是,這里沒有檢測是否所有可選類型都有默認(rèn)值,如果所有的可選類型都需要默認(rèn)值,可以再加上這樣一個工具類型,篩選出所有可選類型。

type Filter<T> = {
? [K in keyof T as undefined extends T[K] ? K : never]: T[K];
};

于是代碼變成了

interface IProps {
? name: string;
? age?: number;
? sex?: string;
}

type Filter<T> = {
? [K in keyof T as undefined extends T[K] ? K : never]: T[K];
};

class DefaultProps extends Component<Required<IProps>, {}> {
? defaultProps: Required<Filter<IProps>> = {
? ? age: 20,
    sex:'male'
? };
? render() {
? ? const { age } = this.props;
? ? console.log(age);
? ? return <div />;
? }
}

如果不寫的話就會提示

圖片.png

結(jié)語

到此這篇關(guān)于淺談React組件props默認(rèn)值的設(shè)置的文章就介紹到這了,更多相關(guān)React組件props默認(rèn)值內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談React Component生命周期函數(shù)

    淺談React Component生命周期函數(shù)

    React組件有哪些生命周期函數(shù)?類組件才有的生命周期函數(shù),分為幾個階段:掛載,更新,卸載,錯誤處理,本文主要介紹了這個階段,感興趣的可以了解一下
    2021-06-06
  • 淺談React Event實現(xiàn)原理

    淺談React Event實現(xiàn)原理

    這篇文章主要介紹了淺談React Event實現(xiàn)原理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • 從頭寫React-like框架的工程搭建實現(xiàn)

    從頭寫React-like框架的工程搭建實現(xiàn)

    這篇文章主要介紹了從頭寫React-like框架的工程搭建實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • React構(gòu)建組件的幾種方式及區(qū)別

    React構(gòu)建組件的幾種方式及區(qū)別

    這篇文章主要介紹了React構(gòu)建組件的幾種方式及區(qū)別,組件就是把圖形、非圖形的各種邏輯均抽象為一個統(tǒng)一的概念來實現(xiàn)開發(fā)的模式文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-08-08
  • React實現(xiàn)文件分片上傳和下載的方法詳解

    React實現(xiàn)文件分片上傳和下載的方法詳解

    在當(dāng)今的前端開發(fā)中,處理文件流操作已經(jīng)成為一個常見的需求,無論是上傳、下載、讀取、展示還是其他的文件處理操作,都需要高效且可靠地處理二進制數(shù)據(jù),本文將深入探討如何使用 React 實現(xiàn)文件分片上傳和下載,并介紹相關(guān)的基本概念和技術(shù),需要的朋友可以參考下
    2023-08-08
  • react 父子組件之間通訊props

    react 父子組件之間通訊props

    這篇文章主要介紹了react 父子組件之間通訊props,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • react中關(guān)于函數(shù)調(diào)用()與bind this的原因及分析

    react中關(guān)于函數(shù)調(diào)用()與bind this的原因及分析

    這篇文章主要介紹了react中關(guān)于函數(shù)調(diào)用()與bind this的原因及分析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • react中使用usestate踩坑及解決

    react中使用usestate踩坑及解決

    這篇文章主要介紹了react中使用usestate踩坑及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • react 可拖拽進度條的實現(xiàn)

    react 可拖拽進度條的實現(xiàn)

    本文主要介紹了react 可拖拽進度條的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • 手挽手帶你學(xué)React之React-router4.x的使用

    手挽手帶你學(xué)React之React-router4.x的使用

    這篇文章主要介紹了手挽手帶你學(xué)React之React-router4.x的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02

最新評論