国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > JS > 正文

React教程之Props驗(yàn)證的具體用法(Props Validation)

2024-05-06 16:39:28
字體:
供稿:網(wǎng)友

Props驗(yàn)證對(duì)于組件的正確使用是一種非常有用的方式。它可以避免隨著你的應(yīng)用的程序越來越復(fù)雜從而出現(xiàn)很多的bug和問題。并且,它還可以是你的程序變得更易讀。

那如何對(duì)Props進(jìn)行驗(yàn)證呢,其實(shí)很簡單,React為我們提供了PropTypes以供驗(yàn)證使用。當(dāng)我們向Props傳入的數(shù)據(jù)無效(也就是向Props傳入的數(shù)據(jù)類型和驗(yàn)證的數(shù)據(jù)類型不符)就會(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è)例子是沒有錯(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ù)類型。還有一種情況就是驗(yàn)證Props是否有值。看下面的代碼

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)然,上面只是簡單的兩種情況。對(duì)于Props的驗(yàn)證,還有很多的東西,驗(yàn)證的形式也有很多,具體我們可以參考React官方文檔。

這里我們有一個(gè)知識(shí)點(diǎn)需要說明一下,就是getDefaultProps。這是默認(rèn)給Props賦值。看下面的代碼

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í)組件沒有傳入Props的時(shí)候,可以保證當(dāng)前組件有默認(rèn)的Props的值。需要注意的是,getDefaultProps的返回結(jié)果是會(huì)被緩存起來的。因此,我們可以直接使用Props,而沒有必要再手動(dòng)編寫一些沒有意義的重復(fù)的代碼。

對(duì)于Props的驗(yàn)證,就介紹到這里。希望本文對(duì)大家有所幫助。也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到JavaScript/Ajax教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 峨眉山市| 霍山县| 乐亭县| 开远市| 普定县| 锦州市| 永顺县| 高阳县| 太保市| 镇康县| 堆龙德庆县| 古蔺县| 九江市| 庆元县| 凌源市| 南开区| 柘荣县| 鲜城| 建昌县| 新龙县| 辽中县| 焦作市| 舟曲县| 徐汇区| 柳州市| 石棉县| 汉沽区| 丽江市| 廉江市| 获嘉县| 五莲县| 颍上县| 肃宁县| 宁海县| 阿勒泰市| 崇阳县| 合作市| 尼木县| 苍溪县| 江安县| 德安县|