1.JSX要加小括號()
如果存在子元素揩慕,則就像在HTML中那樣直接包裹在父元素中即可(注意換行的JSX要加小括號()).
const element = (
<div>
<span>hello</span>
<p>world</p>
</div>
)
2.原則
注意我們將定時(shí)器存儲在了組件實(shí)例上岩瘦,而不是state中揉燃,請先記住一個原則:任何沒有在組件的render()函數(shù)中使用的變量,都不應(yīng)該存放在state中约急。
深度剖析:如何實(shí)現(xiàn)一個 Virtual DOM 算法
3.生命周期小結(jié)
當(dāng)把組件傳遞給ReactDOM.render()函數(shù)后零远,React會調(diào)用組件的構(gòu)造函數(shù)constructor,進(jìn)行一些初始化
然后React會去調(diào)用Clock組件的render()方法將組件渲染出來
當(dāng)組件渲染完畢后厌蔽,React會調(diào)用componentDidMount()生命周期鉤子函數(shù)
當(dāng)setState()函數(shù)被調(diào)用時(shí)牵辣,React會重新調(diào)用組件的render()方法進(jìn)行重繪
當(dāng)組件被從DOM中移除時(shí),React會調(diào)用componentWillUnmount()生命周期鉤子函數(shù)
4.表達(dá)式{}的寫法
你可以傳遞一個字符串作為道具奴饮。這兩個JSX表達(dá)式是等價(jià)的纬向。
<Coustom message="aaa">? ==????<Coustom message={"aaa"}>
5.細(xì)節(jié)記錄
(1):以前一個組件是通過繼承?Component?來構(gòu)建,一個子類就是一個組件戴卜。而用函數(shù)式的組件編寫方式是一個函數(shù)就是一個組件逾条,你可以和以前一樣通過??使用該組件。不同的是投剥,函數(shù)式組件只能接受?props?而無法像跟類組件一樣可以在?constructor?里面初始化?state师脂。你可以理解函數(shù)式組件就是一種只能接受?props和提供?render?方法的類組件。
(2):state?是讓組件控制自己的狀態(tài)薇缅,props?是讓外部對組件自己進(jìn)行配置。
(3):props?一旦傳入攒磨,你就不可以在組件內(nèi)部對它進(jìn)行修改泳桦。但是你可以通過父組件主動重新渲染的方式來傳入新的?props,從而達(dá)到更新的效果娩缰。
(4):文件名的開頭是大寫字母灸撰。我們遵循一個原則:如果一個文件導(dǎo)出的是一個類,那么這個文件名就用大寫開頭。四個組件類文件導(dǎo)出都是類浮毯,所以都是大寫字母開頭完疫。
(5): PropTypes.object.isRequired。
PropTypes.array
PropTypes.bool
PropTypes.func
PropTypes.number
PropTypes.object
PropTypes.string
(6):context 打破了組件和組件之間通過?props?傳遞數(shù)據(jù)的規(guī)范债蓝,極大地增強(qiáng)了組件之間的耦合性壳鹤。而且,就如全局變量一樣饰迹,context 里面的數(shù)據(jù)能被隨意接觸就能被隨意修改芳誓,每個組件都能夠改 context 里面的內(nèi)容會導(dǎo)致程序的運(yùn)行不可預(yù)料。
6.key的理解
c?和?b?的位置互換了啊鸭。但其實(shí) React.js 只需要交換一下 DOM 位置就行了锹淌,但是它并不知道其實(shí)我們只是改變了元素的位置,所以它會重新渲染后面兩個元素(再執(zhí)行 Virtual-DOM 策略)赠制,這樣會大大增加 DOM 操作赂摆。但如果給每個元素加上唯一的標(biāo)識,React.js 就可以知道這兩個元素只是交換了位置钟些。
對于用表達(dá)式套數(shù)組羅列到頁面上的元素烟号,都要為每個元素加上?key?屬性,這個?key?必須是每個元素唯一的標(biāo)識厘唾。一般來說褥符,key?的值可以直接后臺數(shù)據(jù)返回的?id,因?yàn)楹笈_的?id?都是唯一的抚垃。
7.生命周期的理解
(1):我們把?React.js 將組件渲染喷楣,并且構(gòu)造 DOM 元素然后塞入頁面的過程稱為組件的掛載(這個定義請好好記住)鹤树。其實(shí) React.js 內(nèi)部對待每個組件都有這么一個過程铣焊,也就是初始化組件 -> 掛載到頁面上的過程。所以你可以理解一個組件的方法調(diào)用是這么一個過程罕伯;
(2)
-> constructor()
-> componentWillMount()
-> render()
// 然后構(gòu)造 DOM 元素插入頁面
-> componentDidMount()
// ...
// 即將從頁面中刪除
-> componentWillUnmount()
// 從頁面中刪除
(3)總結(jié):
我們一般會把組件的?state?的初始化工作放在?constructor?里面去做曲伊;在?componentWillMount?進(jìn)行組件的啟動工作,例如 Ajax 數(shù)據(jù)拉取追他、定時(shí)器的啟動坟募;組件從頁面上銷毀的時(shí)候,有時(shí)候需要一些數(shù)據(jù)的清理邑狸,例如定時(shí)器的清理懈糯,就會放在?componentWillUnmount?里面去做。
8.ref的使用
<Clokc ref = {(clock)=>this.clock = clock} />
9.屬性寫法注意事項(xiàng)
class? 寫成 className
style={{color:'red'}}