摘要:考慮到是快速入門,于是乎我們就記住一點,當修改值需要重新渲染的時候,的機制是不會讓他全部重新渲染的,它只會把你修改值所在的重新更新。這一生命周期返回的任何值將會作為參數被傳遞給。
安裝react
npm install creat-react-app -g
這里直接安裝react的一個腳手架,里面包含了要用到的許多東西,幫助快速入門react
創(chuàng)建新項目create-react-app my-app
cd my-app
npm start
用腳手架創(chuàng)建一個新的單頁應用,進到項目里面后start跑起來
react組件引入Component組件
JSX語法
渲染虛擬DOM
組件props
組件state
組件嵌套
組件生命周期
組件總覽首先在頭部引入Component組件,然后通過class方式繼承Component,最后將組件導出,即可成為多帶帶組件使用。需要注意的地方就是組件的首字母一定要大寫
//引入Component import {Component} from "react"; //首字母大寫! class MyComponent extends Component{ consturtion(props){ super(props); this.state={ isShow:true } } /*react生命周期函數*/ componentWillMount() {} componentDidMount() {} componentWillReceiveProps() {} shouldComponentUpdate() {} componentWillUpdate() {} componentDidUpdate() {} componentWillUnmount() {} //通過render函數可以將JSX語法渲染成真實dom render() { return (JSX語法) } } //首字母大寫! class Parent extends Component{ return我是組件
{this.props.test}
{this.state.isShow}
} export default Parent;
確實說白了就是html標簽寫到js中去,然后通過babel轉譯成react虛擬DOM對象,然后再渲染。
上例中
render() { return (我是組件,{this.props.test}) }
其實用的就是JSX語法,那么在標簽內可以嵌套js語句。想要嵌套js語句的時候需要用{}包起來。
渲染虛擬DOM關于這一點,要詳細說起來還挺長的。考慮到是快速入門,于是乎我們就記住一點,當修改值需要react重新渲染的時候,react的機制是不會讓他全部重新渲染的,它只會把你修改值所在的dom重新更新。這也是為什么react性能快的一大原因。這個選擇渲染dom的算法叫做diff算法,如果要學習react就不能把這個給忘記。在日后需要好好把這方面的知識補全。這里還要補充的就是,react把JSX語法先轉成react對象,然后通過內部創(chuàng)建節(jié)點插入到dom當中。還是考慮到快速,所以該節(jié)篇幅就不繼續(xù)展開了,這些知識日后需要好好補全。
組件propsprops如果接觸過Vue的話,應該會很好理解這個概念。沒接觸過也不要緊,因為是比較容易接受的。我們這么理解,其實就是父組件傳給子組件的一些東西,可以是基本數據類型,也可以是引用數據類型,也就是說啥都可以傳。子組件可以通過this.props這個對象來獲取父組件傳下來的值
還是看回上面的例子
class MyComponent extends Component{ render() { //這里可以拿到 return (組件state) } } class Parent extends Component{ render() { //通過父組件傳進去 return我是組件
{this.props.test}
{this.state.isShow}
} }
組件state是狀態(tài),這里存放的就是該組件的一些會改變的變量,就是狀態(tài)。比如判斷組件屬性變化,獲取表單值等。修改state會引起react重新渲染,也就是更新狀態(tài)會引起組件刷新。我們可以通過setState()這個函數來設置state的值。不過要注意的是setState()這個函數是異步函數。下面還是看上面的例子
class MyComponent extends Component{ consturtion(props){ super(props); this.state={ isShow:true } } render() { return (組件的嵌套) } }我是組件
{this.props.test}
{this.state.isShow}
這個意思實際上就是在一個組件里面可以用別的組件的意思。因此你可以把組件劃分得比較細致,以便更多的復用。
class Parent extends Component{ render() { //使用了MyComponent組件 return組件生命周期} }
在這里就說一下組件的生命周期函數吧
componentWillMount() {}組件掛載前
componentDidMount() {}組件掛載完執(zhí)行
componentWillReceiveProps() {}組件更新數據時執(zhí)行,props、state
shouldComponentUpdate() {}組件需要更新時執(zhí)行
componentWillUpdate() {}組件更新前執(zhí)行
componentDidUpdate() {}組件更新后執(zhí)行
componentWillUnmount() {}組件銷毀前執(zhí)行
下面一張圖解釋生命周期
當然想要暫時略過也不是不可,但日后需要了解。
16.7 生命周期 裝載constructor
static getDerivedStateFromProps()
render()
componentDidMount()
組件更新static getDerivedStateFromProps()
shouldComponentUpdate()
render()
getSnapshotBeforeUpdate()
componentDidUpdate()
卸載componentWillUnmount()
錯誤處理static getDerivedStateFromError()
componentDidCatch()
constructorconstructor可以初始化state
constructor(props) { super(props); this.state = { color: "#333" }; }
不要直接把props附給state!此模式僅用于你希望故意忽略屬性更新 。
constructor(props) { super(props); // Don"t do this! this.state = { color: props.color }; }componentDidUpdate()
可以用作異步發(fā)請求,該生命周期在組件更新時候給多了一次機會操作dom
componentDidUpdate(prevProps) { // Typical usage (don"t forget to compare props): if (this.props.userID !== prevProps.userID) { this.fetchData(this.props.userID); } }
為了防止重復渲染,如有setstate必須包括在條件中!
shouldComponentUpdate()實際上作為性能優(yōu)化的一種方案,但是不能依賴于它來阻止渲染,因為這樣會引起bug
不推薦做深相等檢測,或使用JSON.stringify()在shouldComponentUpdate()中。這是非常無效率的會傷害性能。
注意,返回false不能阻止子組件當他們的狀態(tài)改變時重新渲染。
static getDerivedStateFromProps()組件實例化后和接受新屬性時將會調用getDerivedStateFromProps。它應該返回一個對象來更新狀態(tài),或者返回null來表明新屬性不需要更新任何狀態(tài)。
getSnapshotBeforeUpdate()getSnapshotBeforeUpdate()在最新的渲染輸出提交給DOM前將會立即調用。
它讓你的組件能在當前的值可能要改變前獲得它們。這一生命周期返回的任何值將會 作為參數被傳遞給componentDidUpdate()。
更深入學習react學完react,我們還需要知道react-router、redux等react全家桶。還在這推薦一個開源框架DVa.js。當然,這是融合的比較好的,如果學有余力不妨去了解了解
附上一張學習路線圖,供大家學習參考
圖片來源:https://github.com/adam-golab/react-developer-roadmap
后話入門react并不難,但是要用得精通卻不容易。本文并不指望能讓你懂多少react,但是如果能帶你入門,那便是他它的成功。希望每個人都能成為自己想要的樣子。
最后,成功不在一朝一夕,我們都需要努力
原創(chuàng)文章,轉載需聯(lián)系
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/96130.html
摘要:一份開發(fā)者必備的技能清單,請查收。入門查漏補缺深入學習查看原圖下載源文件使用快速上手,并了解其中的概念。官方教程入門教程小書文章精讀,問題解答。 一份react開發(fā)者必備的技能清單,請查收。入門、查漏補缺、深入學習... showImg(https://segmentfault.com/img/remote/1460000018000950?w=1965&h=3332); 查看原圖 ...
摘要:本篇解釋中類的控制指令,與指令式界面設計相關。本專欄歷史文章介紹一項讓可以與抗衡的技術可視化開發(fā)工具非正經入門之一三宗罪可視化開發(fā)工具非正經入門之二分離界面設計可視化開發(fā)工具非正經入門之三雙源屬性與數據驅動可視化開發(fā)工具非正經入門之四 本系列博文從 Shadow Widget 作者的視角,解釋該框架的設計要點。本篇解釋 Shadow Widget 中類 Vue 的控制指令,與指令式界面...
摘要:今年以來,的文檔更新很快完善社區(qū)也日漸狀大,再加上于某廠你懂的大力的推廣,的前景十分光明。一般情況下,中小型的系統(tǒng)從遷移到版本大概只需要天的時間。快去動手嘗試吧原創(chuàng)新書移動前端高效開發(fā)實戰(zhàn)已在亞馬遜京東當當開售。 作者:曉飛(滬江Web前端開發(fā)工程師)本文原創(chuàng),轉載請注明作者及出處 Vue.js框架已經火了好長一段時間了,早在2015年的雙11中,淘寶的部分導購業(yè)務——如:雙十一晚會搖...
摘要:一團隊組織網站說明騰訊團隊騰訊前端團隊,代表作品,致力于前端技術的研究騰訊社交用戶體驗設計,簡稱,騰訊設計團隊網站騰訊用戶研究與體驗設計部百度前端研發(fā)部出品淘寶前端團隊用技術為體驗提供無限可能凹凸實驗室京東用戶體驗設計部出品奇舞團奇虎旗下前 一、團隊組織 網站 說明 騰訊 AlloyTeam 團隊 騰訊Web前端團隊,代表作品WebQQ,致力于前端技術的研究 ISUX 騰...
閱讀 2577·2021-11-22 13:53
閱讀 4085·2021-09-28 09:47
閱讀 870·2021-09-22 15:33
閱讀 820·2020-12-03 17:17
閱讀 3321·2019-08-30 13:13
閱讀 2126·2019-08-29 16:09
閱讀 1183·2019-08-29 12:24
閱讀 2455·2019-08-28 18:14