react隨記3 組件&Props

組件& Props

組件可以將UI上的內(nèi)容分成一個(gè)個(gè)的獨(dú)立的部分,這些組件可復(fù)用嚼吞。
組件從概念上來(lái)看很像函數(shù)盒件,接受任意的輸入值(稱(chēng)之為props),并返回一個(gè)React元素舱禽。
組件分為兩類(lèi)炒刁,一類(lèi)是函數(shù)組件,一類(lèi)是類(lèi)組件誊稚。分別如下:

  • 函數(shù)組件:函數(shù)組件就是用JavaScript的函數(shù)切心,但是函數(shù)名首字母必須是大寫(xiě)飒筑。
function Welcome(props) {
  return <h1>hello world!</h1>
}
ReactDOM.render(
  <Welcome />, document.getElementById('root')
);

可以看到渲染結(jié)果:


image.png

如果把函數(shù)組件名稱(chēng)Welcome改成小寫(xiě)字母開(kāi)頭welcome片吊,則沒(méi)有進(jìn)行渲染:

image.png

  • 類(lèi)組件:可以使用ES6的class來(lái)定義組件:
class Welcome extends React.Component {
  render() {
    return <h1>hello world!</h1>  ;
  }
}
ReactDOM.render(
  <Welcome />, document.getElementById('root')
);

使用類(lèi)組件的命名規(guī)則同函數(shù)組件一樣绽昏。

組件渲染

React元素不僅可以使瀏覽器DOM標(biāo)簽,也可以是用戶(hù)自定義的組件俏脊,當(dāng)React遇到元素是用戶(hù)自定義組件時(shí)全谤,會(huì)把JSX屬性作為一個(gè)對(duì)象傳遞給該組件,這個(gè)對(duì)象被叫做props爷贫。也就是你需要給這個(gè)組件傳遞參數(shù)的時(shí)候认然,就會(huì)用到這個(gè)對(duì)象。

function Welcome(props) {
  return <h1>hello ,{props.name}!</h1>
}
const element = <Welcome name="jianshu" />
ReactDOM.render(
  element, document.getElementById("root")
);

<Welcome>可以認(rèn)為是同<h1>等價(jià)的標(biāo)簽漫萄,可以對(duì)其進(jìn)行多個(gè)屬性的定義卷员,如上代碼,就是定義了name屬性腾务,并賦值為"jianshu"毕骡,那么屬性name和屬性值jianshu都傳遞給了對(duì)象props,可以認(rèn)為props就是一個(gè)對(duì)象岩瘦,也有了name屬性及其值未巫。當(dāng)然,作為對(duì)象启昧,那就可以有多個(gè)屬性叙凡,都可以進(jìn)行聲明和傳遞,如下圖:

image.png

如上文所述:
組件名稱(chēng)必須以大寫(xiě)字母開(kāi)頭密末。 例如握爷,<div /> 表示一個(gè)DOM標(biāo)簽,但 <Welcome /> 表示一個(gè)組件严里,并且在使用該組件時(shí)你必須定義或引入它新啼。

組件組合

組件可以在他的輸出中引用其他組件,這就可以讓我們使用同一個(gè)組件抽象出任意層次的細(xì)節(jié)田炭。例如如下代碼师抄,在App組件,用來(lái)多次渲染W(wǎng)elcome組件:

function Welcome(props) {
  return <h1>hello {props.name}</h1>
}

function App() {
  return (
    <div>
       <Welcome name="jianshu" />
       <Welcome name="zhihu" />
       <Welcome name="weibo" />   
     </div>
  );
}

ReactDOM.render(
  <App />, document.getElementById("root")
);

組件的返回值只能有一個(gè)根元素教硫。這也是我們要用一個(gè)<div>來(lái)包裹所有<Welcome />元素的原因叨吮。

Props的只讀性

不管是使用函數(shù)組件還是類(lèi)組件,在組件內(nèi)部是不能修改自己的props的瞬矩。也就是外部傳入給props對(duì)象的屬性茶鉴,是只讀的。
來(lái)看下如下的sum函數(shù):

function sum(a,b) {
  return a + b;
}

類(lèi)似與這種的函數(shù)成為純函數(shù)景用,函數(shù)沒(méi)有改變自己的輸入值涵叮,只要傳入的值是相同的惭蹂,返回的結(jié)果永遠(yuǎn)相同。
與之對(duì)應(yīng)的是非純函數(shù)割粮,函數(shù)會(huì)改變自己的輸入值:

function withdraw(account, amount) {
  account.total -= amount;
}

React有嚴(yán)格的規(guī)定:
所有的React組件必須向春函數(shù)那樣使用它們的props盾碗。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市舀瓢,隨后出現(xiàn)的幾起案子廷雅,更是在濱河造成了極大的恐慌,老刑警劉巖京髓,帶你破解...
    沈念sama閱讀 218,204評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件航缀,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡堰怨,警方通過(guò)查閱死者的電腦和手機(jī)芥玉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)备图,“玉大人灿巧,你說(shuō)我怎么就攤上這事∥芘耄” “怎么了砸烦?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,548評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)绞吁。 經(jīng)常有香客問(wèn)我幢痘,道長(zhǎng),這世上最難降的妖魔是什么家破? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,657評(píng)論 1 293
  • 正文 為了忘掉前任颜说,我火速辦了婚禮,結(jié)果婚禮上汰聋,老公的妹妹穿的比我還像新娘门粪。我一直安慰自己,他們只是感情好烹困,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,689評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布玄妈。 她就那樣靜靜地躺著,像睡著了一般髓梅。 火紅的嫁衣襯著肌膚如雪拟蜻。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,554評(píng)論 1 305
  • 那天枯饿,我揣著相機(jī)與錄音酝锅,去河邊找鬼。 笑死奢方,一個(gè)胖子當(dāng)著我的面吹牛搔扁,可吹牛的內(nèi)容都是我干的爸舒。 我是一名探鬼主播,決...
    沈念sama閱讀 40,302評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼稿蹲,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼扭勉!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起场绿,我...
    開(kāi)封第一講書(shū)人閱讀 39,216評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤剖效,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后焰盗,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,661評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡咒林,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,851評(píng)論 3 336
  • 正文 我和宋清朗相戀三年熬拒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片垫竞。...
    茶點(diǎn)故事閱讀 39,977評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡澎粟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出欢瞪,到底是詐尸還是另有隱情活烙,我是刑警寧澤,帶...
    沈念sama閱讀 35,697評(píng)論 5 347
  • 正文 年R本政府宣布遣鼓,位于F島的核電站啸盏,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏骑祟。R本人自食惡果不足惜回懦,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,306評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望次企。 院中可真熱鬧怯晕,春花似錦、人聲如沸缸棵。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,898評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)堵第。三九已至吧凉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間型诚,已是汗流浹背客燕。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,019評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留狰贯,地道東北人也搓。 一個(gè)月前我還...
    沈念sama閱讀 48,138評(píng)論 3 370
  • 正文 我出身青樓赏廓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親傍妒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子幔摸,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,927評(píng)論 2 355