React中props詳講+例子

組件實(shí)對(duì)象3大屬性之一:props屬性

  • 1.每個(gè)組件對(duì)象都會(huì)有props(properties的簡(jiǎn)寫(xiě))屬性
  • 2.組件標(biāo)簽的所有屬性都保存在props中
  • 3.內(nèi)部讀取某個(gè)屬性值:this.props.propertyName
  • 4.作用:通過(guò)標(biāo)簽屬性從組件外 向組件內(nèi)傳遞數(shù)據(jù)(只讀 read only)
  • 5.對(duì)props中的屬性值進(jìn)行類(lèi)型限制和必要性限制
Person.propTypes = {
      name: React.PropTypes.string.isRequired,
      age: React.PropTypes.number.isRequired
 }
  • 6.擴(kuò)展屬性:將對(duì)象的所有屬性通過(guò)props傳遞
<Person {...person}/>
  • 7.默認(rèn)屬性值
Person.defaultProps = {
      name: 'Mary'
};
  • 8.組件類(lèi)的構(gòu)造函數(shù)
constructor (props) {
      super(props);
      console.log(props); // 查看所有屬性
    }

問(wèn)題:為什么要設(shè)計(jì)對(duì)prop進(jìn)行約束的語(yǔ)法刃麸?

下面來(lái)記錄一個(gè)簡(jiǎn)單的例子:

需求:自定義用來(lái)顯示一個(gè)人員信息的組件, 效果如頁(yè)面. 說(shuō)明
1). 如果性別沒(méi)有指定, 默認(rèn)為男
2). 如果年齡沒(méi)有指定, 默認(rèn)為18

class Person extends React.Component {

    constructor(props) {
      super(props);
      console.log(props); //查看所有屬性
    }

    render() {
      return (
        <ul>
          <li>姓名: {this.props.name}</li>
          <li>性別: {this.props.sex}</li>
          <li>年齡: {this.props.age}</li>
        </ul>
      );
    }
  }

  Person.propTypes = {
   name: React.PropTypes.string.isRequired,
   sex: React.PropTypes.string.isRequired,
   age: React.PropTypes.number.isRequired
  };

  Person.defaultProps = {
    sex: '男',
    age: 18
  };

  /************************************************************************/

  //初始化數(shù)據(jù)
  let person = {name: 'atguigu', sex: '女', age: 3};
  // person = { name: 'atguigu', sex: '女', age: "3" }; // 會(huì)拋出警告age不是number類(lèi)型的

  //根據(jù)數(shù)據(jù)動(dòng)態(tài)渲染組件標(biāo)簽
  /*ReactDOM.render(<Person name={person.name} age={person.age} sex={person.sex}/>,
      document.getElementById('example'));*/
  ReactDOM.render(<Person {...person}/>,
      document.getElementById('example'));

  const person2 = {name: 'kobe', sex: '女'};
  ReactDOM.render(<Person {...person2}/>, document.getElementById('example2'));

組件拆分

/*
   1. 拆分組件: 拆分界面, 抽取組件
     * 單個(gè)標(biāo)題組件: Welcome
     * 應(yīng)用組件: App
   2. 分析確定傳遞數(shù)據(jù)和數(shù)據(jù)類(lèi)型
     * Welcome: props.name  string
     * App: props.names    array
   */

  //定義內(nèi)部標(biāo)題組件
  class Welcome extends React.Component {
    render() {
      return <h2>Welcome {this.props.name}!</h2>;
    }
  }
  Welcome.propTypes = {
    name: React.PropTypes.string.isRequired
  };
  //定義外部應(yīng)用組件
  class App extends React.Component {
    render() {
      return (
        <div>
          {
            this.props.names.map(
              (name, index) => <Welcome name={name} key={index}/>
            )
          }
        </div>
      );
    }
  }
  App.propTypes = {
    names: React.PropTypes.array.isRequired
  };

  /**********************************************************/

  var names = ['Tom', 'Jack', "Bob"];
  ReactDOM.render(<App names={names}/>, document.getElementById('example'));
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末些膨,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子桥氏,更是在濱河造成了極大的恐慌青灼,老刑警劉巖卷仑,帶你破解...
    沈念sama閱讀 216,402評(píng)論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件孽尽,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡毁葱,警方通過(guò)查閱死者的電腦和手機(jī)垫言,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)倾剿,“玉大人筷频,你說(shuō)我怎么就攤上這事∏岸唬” “怎么了凛捏?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,483評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)芹缔。 經(jīng)常有香客問(wèn)我坯癣,道長(zhǎng),這世上最難降的妖魔是什么最欠? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,165評(píng)論 1 292
  • 正文 為了忘掉前任坡锡,我火速辦了婚禮蓬网,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘鹉勒。我一直安慰自己,他們只是感情好吵取,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布禽额。 她就那樣靜靜地躺著,像睡著了一般皮官。 火紅的嫁衣襯著肌膚如雪脯倒。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,146評(píng)論 1 297
  • 那天捺氢,我揣著相機(jī)與錄音藻丢,去河邊找鬼。 笑死摄乒,一個(gè)胖子當(dāng)著我的面吹牛悠反,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播馍佑,決...
    沈念sama閱讀 40,032評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼斋否,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了拭荤?” 一聲冷哼從身側(cè)響起茵臭,我...
    開(kāi)封第一講書(shū)人閱讀 38,896評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎舅世,沒(méi)想到半個(gè)月后旦委,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,311評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡雏亚,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評(píng)論 2 332
  • 正文 我和宋清朗相戀三年缨硝,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片评凝。...
    茶點(diǎn)故事閱讀 39,696評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡追葡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出奕短,到底是詐尸還是另有隱情宜肉,我是刑警寧澤,帶...
    沈念sama閱讀 35,413評(píng)論 5 343
  • 正文 年R本政府宣布翎碑,位于F島的核電站谬返,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏日杈。R本人自食惡果不足惜遣铝,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評(píng)論 3 325
  • 文/蒙蒙 一佑刷、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧酿炸,春花似錦瘫絮、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至扁眯,卻和暖如春壮莹,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背姻檀。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,815評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工命满, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人绣版。 一個(gè)月前我還...
    沈念sama閱讀 47,698評(píng)論 2 368
  • 正文 我出身青樓胶台,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親僵娃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子概作,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評(píng)論 2 353