React入門系列教程(四)使用PropTypes驗(yàn)證自定義組件屬性類型

先創(chuàng)建一個(gè)自定義組件,這次不用箭頭函數(shù),用普通函數(shù)。

//這是個(gè)用函數(shù)方式創(chuàng)建的自定義組件升略,記得函數(shù)名首字母大寫
function Hi(props) {
    return (
        <div>
            你好, {props.lastName} {props.firstName}
        </div>
    )
}

我們來使用一下:

<div id="rootElement"></div>
<script src="https://unpkg.com/react@16.8.3/umd/react.production.min.js"></script>
<script src="https://unpkg.com/react-dom@16.8.3/umd/react-dom.production.min.js"></script>
<script src="https://unpkg.com/babel-standalone@6.26.0/babel.min.js"></script>
<script type="text/babel">
    const rootElement = document.getElementById('rootElement')
    
    function Hi(props) {
        return (
            <div>
                你好, {props.lastName} {props.firstName}
            </div>
        )
    }
    
    ReactDOM.render(<Hi firstName={true} />, rootElement)
</script>

Hi組件使用到了兩個(gè)屬性,并且這兩個(gè)屬性很明顯是string類型屡限,然而在使用中我們給firstName屬性傳入了一個(gè)bool類型的值品嚣,沒有給lastName屬性賦值。

有沒有辦法給屬性值加上類型檢查之類的驗(yàn)證呢钧大?使用組件的靜態(tài)propTypes屬性翰撑,它是個(gè)對(duì)象。比如我們要給firstName加上驗(yàn)證拓型,那就要在propTypes中添加一個(gè)鍵名為firstName额嘿,鍵值為一個(gè)函數(shù),函數(shù)有三個(gè)輸入?yún)?shù)劣挫,分別是propspropName东帅,componentName压固。來看下怎么用:

<div id="rootElement"></div>
<!-- <script src="https://unpkg.com/react@16.8.3/umd/react.production.min.js"></script> -->
<!-- react庫用development版本,propTypes才會(huì)起作用 -->
<script src="https://unpkg.com/react@16.8.3/umd/react.development.js"></script>
<script src="https://unpkg.com/react-dom@16.8.3/umd/react-dom.production.min.js"></script>
<script src="https://unpkg.com/babel-standalone@6.26.0/babel.min.js"></script>
<script type="text/babel">
    const rootElement = document.getElementById('rootElement')
    
    function Hi(props) {
        return (
            <div>
                你好, {props.lastName} {props.firstName}
            </div>
        )
    }
    
    Hi.propTypes = {
        //props就是Hi組件的props靠闭,propName這里就是firstName
        firstName(props, propName, componentName) {
            //props[propName]就是取得Hi組件firstName的值
            if(typeof props[propName] !== 'string') {
                return new Error(`${componentName}的${propName}屬性的值應(yīng)是字符串類型`)
            }
        }
    }
    
    ReactDOM.render(<Hi firstName={true} />, rootElement)
</script>

效果如圖1帐我。

圖1

firstNamelastName的驗(yàn)證是一樣的,之前提到過復(fù)用愧膀,我們可以把公共代碼抽取成一個(gè)函數(shù)拦键。

<div id="rootElement"></div>
<!-- <script src="https://unpkg.com/react@16.8.3/umd/react.production.min.js"></script> -->
<!-- react庫用development版本,propTypes才會(huì)起作用 -->
<script src="https://unpkg.com/react@16.8.3/umd/react.development.js"></script>
<script src="https://unpkg.com/react-dom@16.8.3/umd/react-dom.production.min.js"></script>
<script src="https://unpkg.com/babel-standalone@6.26.0/babel.min.js"></script>
<script type="text/babel">
    const rootElement = document.getElementById('rootElement')
    
    function Hi(props) {
        return (
            <div>
                你好, {props.lastName} {props.firstName}
            </div>
        )
    }
    
    //公共代碼包裹到string函數(shù)里檩淋,并放到一個(gè)對(duì)象中統(tǒng)一管理
    const PropTypes = {
        string(props, propName, componentName) {
            if(typeof props[propName] !== 'string') {
                return new Error(`${componentName}的${propName}屬性的值應(yīng)是字符串類型`)
            }
        }
    }
    
    Hi.propTypes = {
        //鍵為要驗(yàn)證的屬性名芬为,值為函數(shù)
        firstName: PropTypes.string,
        lastName: PropTypes.string
    }
    
    ReactDOM.render(<Hi firstName={true} />, rootElement)
</script>

其實(shí)react團(tuán)隊(duì)早已為我們準(zhǔn)備好了PropTypes包供我們使用,我們只要引入就好了蟀悦。

<div id="rootElement"></div>
<!-- <script src="https://unpkg.com/react@16.8.3/umd/react.production.min.js"></script> -->
<!-- react庫用development版本媚朦,propTypes才會(huì)起作用 -->
<script src="https://unpkg.com/react@16.8.3/umd/react.development.js"></script>
<script src="https://unpkg.com/react-dom@16.8.3/umd/react-dom.production.min.js"></script>
<script src="https://unpkg.com/prop-types@15.7.2/prop-types.js"></script>
<script src="https://unpkg.com/babel-standalone@6.26.0/babel.min.js"></script>
<script type="text/babel">
    const rootElement = document.getElementById('rootElement')
    
    function Hi(props) {
        return (
            <div>
                你好, {props.lastName} {props.firstName}
            </div>
        )
    }
    
    Hi.propTypes = {
        //引入prop-types后,使用方式和之前相同
        firstName: PropTypes.string,
        lastName: PropTypes.string
    }
    
    ReactDOM.render(<Hi firstName={true} />, rootElement)
</script>

更具體的使用方式請(qǐng)查看prop-types包的文檔日戈。

其實(shí)定義react組件不僅可以使用函數(shù)的方式询张,還可以使用class,也就是類的方式來定義浙炼。用類的方式定義的組件如何使用prop-types包呢份氧?看代碼:

<div id="rootElement"></div>
<!-- <script src="https://unpkg.com/react@16.8.3/umd/react.production.min.js"></script> -->
<!-- react庫用development版本唯袄,propTypes才會(huì)起作用 -->
<script src="https://unpkg.com/react@16.8.3/umd/react.development.js"></script>
<script src="https://unpkg.com/react-dom@16.8.3/umd/react-dom.production.min.js"></script>
<script src="https://unpkg.com/prop-types@15.7.2/prop-types.js"></script>
<script src="https://unpkg.com/babel-standalone@6.26.0/babel.min.js"></script>
<script type="text/babel">
    const rootElement = document.getElementById('rootElement')
    
    class Hi extends React.Component {
        //定義成靜態(tài)屬性
        static propTypes = {
            firstName: PropTypes.string,
            lastName: PropTypes.string
        }
        
        render() {
            const {lastName, firstName} = this.props
            return (
                <div>
                    你好, {lastName} {firstName}
                </div>
            )
        }
    }
    
    ReactDOM.render(<Hi firstName={true} />, rootElement)
</script>

最后提醒大家注意,當(dāng)你要真正發(fā)布產(chǎn)品的時(shí)候蜗帜,請(qǐng)使用react.production包恋拷,它不會(huì)使用PropTypes,因?yàn)?code>PropTypes會(huì)大大降低程序的性能钮糖。所以我們?cè)陂_發(fā)的時(shí)候才用react.development梅掠。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市店归,隨后出現(xiàn)的幾起案子阎抒,更是在濱河造成了極大的恐慌,老刑警劉巖消痛,帶你破解...
    沈念sama閱讀 217,734評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件且叁,死亡現(xiàn)場離奇詭異,居然都是意外死亡秩伞,警方通過查閱死者的電腦和手機(jī)逞带,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來纱新,“玉大人展氓,你說我怎么就攤上這事×嘲” “怎么了遇汞?”我有些...
    開封第一講書人閱讀 164,133評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長簿废。 經(jīng)常有香客問我空入,道長,這世上最難降的妖魔是什么族檬? 我笑而不...
    開封第一講書人閱讀 58,532評(píng)論 1 293
  • 正文 為了忘掉前任歪赢,我火速辦了婚禮,結(jié)果婚禮上单料,老公的妹妹穿的比我還像新娘埋凯。我一直安慰自己,他們只是感情好看尼,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,585評(píng)論 6 392
  • 文/花漫 我一把揭開白布递鹉。 她就那樣靜靜地躺著,像睡著了一般藏斩。 火紅的嫁衣襯著肌膚如雪躏结。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,462評(píng)論 1 302
  • 那天狰域,我揣著相機(jī)與錄音媳拴,去河邊找鬼黄橘。 笑死,一個(gè)胖子當(dāng)著我的面吹牛屈溉,可吹牛的內(nèi)容都是我干的塞关。 我是一名探鬼主播,決...
    沈念sama閱讀 40,262評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼子巾,長吁一口氣:“原來是場噩夢啊……” “哼帆赢!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起线梗,我...
    開封第一講書人閱讀 39,153評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤椰于,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后仪搔,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體瘾婿,經(jīng)...
    沈念sama閱讀 45,587評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,792評(píng)論 3 336
  • 正文 我和宋清朗相戀三年烤咧,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了偏陪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,919評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡煮嫌,死狀恐怖笛谦,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情昌阿,我是刑警寧澤揪罕,帶...
    沈念sama閱讀 35,635評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站宝泵,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏轩娶。R本人自食惡果不足惜儿奶,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,237評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望鳄抒。 院中可真熱鬧闯捎,春花似錦、人聲如沸许溅。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽贤重。三九已至茬祷,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間并蝗,已是汗流浹背祭犯。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評(píng)論 1 269
  • 我被黑心中介騙來泰國打工秸妥, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人沃粗。 一個(gè)月前我還...
    沈念sama閱讀 48,048評(píng)論 3 370
  • 正文 我出身青樓粥惧,卻偏偏與公主長得像,于是被迫代替她去往敵國和親最盅。 傳聞我的和親對(duì)象是個(gè)殘疾皇子突雪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,864評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容