React教程之Props驗(yàn)證的具體用法(Props Validation)
Props驗(yàn)證對(duì)于組件的正確使用是一種非常有用的方式。它可以避免隨著你的應(yīng)用的程序越來(lái)越復(fù)雜從而出現(xiàn)很多的bug和問(wèn)題。并且,它還可以是你的程序變得更易讀。
那如何對(duì)Props進(jìn)行驗(yàn)證呢,其實(shí)很簡(jiǎn)單,React為我們提供了PropTypes以供驗(yàn)證使用。當(dāng)我們向Props傳入的數(shù)據(jù)無(wú)效(也就是向Props傳入的數(shù)據(jù)類(lèi)型和驗(yàn)證的數(shù)據(jù)類(lèi)型不符)就會(huì)在控制臺(tái)發(fā)出警告信息。
看下面的例子
var Propsva = React.createClass({
propTypes: {
optionalArray: React.PropTypes.array,
optionalBool: React.PropTypes.bool,
optionalFunc: React.PropTypes.func,
optionalNumber: React.PropTypes.number,
optionalObject: React.PropTypes.object,
optionalString: React.PropTypes.string,
},
getDefaultProps:function(){
return {
optionalArray: ['onmpw.com','——跡憶博客'],
optionalBool: true,
optionalFunc: function (arg) {
console.log(arg);
},
optionalNumber: 3,
optionalObject: {
object1: "objectvalue1",
object2: "objectvalue2",
object3: "objectvalue3",
},
optionalString: "My Onmpw",
};
},
render:function(){
return (
<div>
<h3>Array:{this.props.optionalArray}</h3>
<h3>Bool:{this.props.optionalBool}</h3>
<h3 onClick={this.props.optionalFunc}>Func:click</h3>
<h3>Number:{this.props.optionalNumber}</h3>
<h3>Object:{this.props.optionalObject.object1}</h3>
<h3>Object:{this.props.optionalObject.object2}</h3>
<h3>Object:{this.props.optionalObject.object3}</h3>
<h3>String:{this.props.optionalString}</h3>
</div>
);
}
});
ReactDOM.render(
<Propsva />,
document.getElementById('content')
);
當(dāng)然,上面這個(gè)例子是沒(méi)有錯(cuò)誤的。下面我們將上面的例子進(jìn)行修改
getDefaultProps:function(){
return {
optionalArray: 'onmpw.com——跡憶博客',
optionalBool: true,
optionalFunc: function (arg) {
console.log(arg);
},
optionalNumber: 3,
optionalObject: {
object1: "objectvalue1",
object2: "objectvalue2",
object3: "objectvalue3",
},
optionalString: "My Onmpw",
};
},
然后,我們會(huì)在控制臺(tái)中發(fā)現(xiàn)有如下的警告
Warning: Failed propType: Invalid prop `optionalArray` of type `string` supplied to `Propsva`, expected `array`.
這是一種情況,驗(yàn)證Props的數(shù)據(jù)類(lèi)型。還有一種情況就是驗(yàn)證Props是否有值??聪旅娴拇a
propTypes: {
optionalArray: React.PropTypes.array.isRequired,
optionalBool: React.PropTypes.bool.isRequired,
optionalFunc: React.PropTypes.func,
optionalNumber: React.PropTypes.number,
optionalObject: React.PropTypes.object,
optionalString: React.PropTypes.string,
},
在React.PropTypes.array和React.PropTypes.bool后面加上isRequired,表示optionalArray和optionalBool兩項(xiàng)是必須有值的
getDefaultProps:function(){
return {
optionalFunc: function (arg) {
console.log(arg);
},
optionalNumber: 3,
optionalObject: {
object1: "objectvalue1",
object2: "objectvalue2",
object3: "objectvalue3",
},
optionalString: "My Onmpw",
};
},
在上面代碼中我們將optionalArray和optionalBool去掉,然后再去瀏覽器中運(yùn)行代碼,會(huì)發(fā)現(xiàn)控制臺(tái)報(bào)如下的錯(cuò)誤
Warning: Failed propType: Required prop `optionalArray` was not specified in `Propsva`.
Warning: Failed propType: Required prop `optionalBool` was not specified in `Propsva`.
當(dāng)然,上面只是簡(jiǎn)單的兩種情況。對(duì)于Props的驗(yàn)證,還有很多的東西,驗(yàn)證的形式也有很多,具體我們可以參考React官方文檔。
這里我們有一個(gè)知識(shí)點(diǎn)需要說(shuō)明一下,就是getDefaultProps。這是默認(rèn)給Props賦值??聪旅娴拇a
var ComponentDefaultProps = React.createClass({
getDefaultProps: function() {
return {
value: 'Default Value'
};
},
render:function(){
return (
<div>{this.props.value}</div>
)
}
});
ReactDOM.render(
<ComponentDefaultProps />,
document.getElementById('content')
);
getDefaultProps()可以保證,當(dāng)父級(jí)組件沒(méi)有傳入Props的時(shí)候,可以保證當(dāng)前組件有默認(rèn)的Props的值。需要注意的是,getDefaultProps的返回結(jié)果是會(huì)被緩存起來(lái)的。因此,我們可以直接使用Props,而沒(méi)有必要再手動(dòng)編寫(xiě)一些沒(méi)有意義的重復(fù)的代碼。
對(duì)于Props的驗(yàn)證,就介紹到這里。希望本文對(duì)大家有所幫助。也希望大家多多支持腳本之家。
相關(guān)文章
react-three/postprocessing庫(kù)的參數(shù)中文含義使用解析
這篇文章主要介紹了react-three/postprocessing庫(kù)的參數(shù)中文含義使用總結(jié),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05
React進(jìn)行路由變化監(jiān)聽(tīng)的解決方案
在現(xiàn)代單頁(yè)應(yīng)用(SPA)中,路由管理是至關(guān)重要的一部分,它不僅決定了用戶(hù)如何在頁(yè)面間切換,還直接影響到整個(gè)應(yīng)用的性能和用戶(hù)體驗(yàn),這些看似不起眼的問(wèn)題,往往會(huì)導(dǎo)致功能錯(cuò)亂和性能下降,本篇文章將深入探討在 React 中如何高效監(jiān)聽(tīng)路由變化,需要的朋友可以參考下2025-01-01
Hello?React的組件化方式之React入門(mén)小案例演示
這篇文章主要介紹了Hello?React的組件化方式-React入門(mén)小案例,本文通過(guò)Hello?React的案例,?來(lái)體驗(yàn)一下React開(kāi)發(fā)模式,?以及jsx的語(yǔ)法,需要的朋友可以參考下2022-10-10
react自適應(yīng)布局px轉(zhuǎn)rem實(shí)現(xiàn)示例詳解
這篇文章主要為大家介紹了react自適應(yīng)布局px轉(zhuǎn)rem實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
詳解Jotai Immer如何實(shí)現(xiàn)undo redo功能示例詳解
這篇文章主要為大家介紹了詳解Jotai Immer如何實(shí)現(xiàn)undo redo功能示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
淺談react-native熱更新react-native-pushy集成遇到的問(wèn)題
下面小編就為大家?guī)?lái)一篇淺談react-native熱更新react-native-pushy集成遇到的問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09

