react 簡要心得

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'}}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末单雾,一起剝皮案震驚了整個濱河市赚哗,隨后出現(xiàn)的幾起案子她紫,更是在濱河造成了極大的恐慌,老刑警劉巖屿储,帶你破解...
    沈念sama閱讀 206,311評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件贿讹,死亡現(xiàn)場離奇詭異,居然都是意外死亡够掠,警方通過查閱死者的電腦和手機(jī)民褂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來祖屏,“玉大人助赞,你說我怎么就攤上這事≡祝” “怎么了雹食?”我有些...
    開封第一講書人閱讀 152,671評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長期丰。 經(jīng)常有香客問我群叶,道長,這世上最難降的妖魔是什么钝荡? 我笑而不...
    開封第一講書人閱讀 55,252評論 1 279
  • 正文 為了忘掉前任街立,我火速辦了婚禮,結(jié)果婚禮上埠通,老公的妹妹穿的比我還像新娘端辱。我一直安慰自己舞蔽,他們只是感情好个盆,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著终惑,像睡著了一般狠鸳。 火紅的嫁衣襯著肌膚如雪件舵。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,031評論 1 285
  • 那天,我揣著相機(jī)與錄音盟庞,去河邊找鬼。 笑死不狮,一個胖子當(dāng)著我的面吹牛摇零,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播雾家,決...
    沈念sama閱讀 38,340評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼竹揍,長吁一口氣:“原來是場噩夢啊……” “哼芬位!你這毒婦竟也來了英染?” 一聲冷哼從身側(cè)響起四康,我...
    開封第一講書人閱讀 36,973評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎囱嫩,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體损俭,經(jīng)...
    沈念sama閱讀 43,466評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡琐脏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評論 2 323
  • 正文 我和宋清朗相戀三年惰蜜,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了抛猖。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片联四。...
    茶點(diǎn)故事閱讀 38,039評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡收苏,死狀恐怖怠噪,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情矫夷,我是刑警寧澤葛闷,帶...
    沈念sama閱讀 33,701評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站双藕,受9級特大地震影響淑趾,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜忧陪,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評論 3 307
  • 文/蒙蒙 一扣泊、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧嘶摊,春花似錦延蟹、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至虱颗,卻和暖如春沥匈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背忘渔。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工高帖, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人畦粮。 一個月前我還...
    沈念sama閱讀 45,497評論 2 354
  • 正文 我出身青樓散址,卻偏偏與公主長得像,于是被迫代替她去往敵國和親宣赔。 傳聞我的和親對象是個殘疾皇子爪飘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 以下內(nèi)容是我在學(xué)習(xí)和研究React時(shí),對React的特性拉背、重點(diǎn)和注意事項(xiàng)的提取师崎、精練和總結(jié),可以做為React特性...
    科研者閱讀 8,219評論 2 21
  • 本筆記基于React官方文檔椅棺,當(dāng)前React版本號為15.4.0犁罩。 1. 安裝 1.1 嘗試 開始之前可以先去co...
    Awey閱讀 7,649評論 14 128
  • 3. JSX JSX是對JavaScript語言的一個擴(kuò)展語法齐蔽, 用于生產(chǎn)React“元素”,建議在描述UI的時(shí)候...
    pixels閱讀 2,806評論 0 24
  • 猶記當(dāng)年冬日里床估,年終一曲歌繞梁含滴。十年彈指仍回味,遠(yuǎn)渡英倫嫁異鄉(xiāng)丐巫。今日相聚人依舊谈况,滿面春風(fēng)話語長。喝茶品肴殷勤待递胧,遠(yuǎn)...
    九天神游閱讀 283評論 0 0
  • 高中同學(xué)更新動態(tài)碑韵,三五老友在評論里嘰嘰喳喳,追憶往事缎脾,一會兒就有人感慨“放假約起來”眾人呼應(yīng)“約起來祝闻、約起來”。 ...
    探軼閱讀 423評論 2 1