摘要:如果需要交互,應(yīng)該在生命周期中進(jìn)行交互。生命周期過(guò)程中涉及三個(gè)主要的動(dòng)作術(shù)語(yǔ)表示正在掛接虛擬到真實(shí)。每當(dāng)組件第一次加載到中的時(shí)候,我們都想生成定時(shí)器,表示正在被重新渲染。組件是真正隔離的每一個(gè)都會(huì)建立自己的定時(shí)器,并獨(dú)立的更新。
state & 生命周期 state
我們之前實(shí)現(xiàn)的時(shí)鐘,實(shí)現(xiàn)方式是每個(gè)一秒進(jìn)行一次渲染dom,但是這種方法并不合理。我們想要通過(guò)一種狀態(tài)來(lái)控制組件,實(shí)現(xiàn)更優(yōu)的渲染。
state
React 把組件看成是一個(gè)狀態(tài)機(jī)(State Machines)。通過(guò)與用戶的交互,實(shí)現(xiàn)不同狀態(tài),然后渲染 UI,讓用戶界面和數(shù)據(jù)保持一致。React 里,只需更新組件的 state,然后根據(jù)新的 state 重新渲染用戶界面(不要操作 DOM)。
原生方法
Document
類
Document
props與state的區(qū)別
props不能被其所在的組件修改,從父組件傳遞進(jìn)來(lái)的屬性不會(huì)在組件內(nèi)部更改; state只能在所在組件內(nèi)部更改,或在外部調(diào)用setState函數(shù)對(duì)狀態(tài)進(jìn)行間接修改。
render成員函數(shù)
首先說(shuō)render是一個(gè)函數(shù),它對(duì)于組件來(lái)說(shuō),render成員函數(shù)是必需的。render函數(shù)的主要流程是檢測(cè)this.props和this.state,再返回一個(gè)單一組件實(shí)例。 render函數(shù)應(yīng)該是純粹的,也就是說(shuō),在render函數(shù)內(nèi)不應(yīng)該修改組件state,不讀寫DOM信息,也不與瀏覽器交互。如果需要交互,應(yīng)該在生命周期中進(jìn)行交互。生命周期
過(guò)程中涉及三個(gè)主要的動(dòng)作術(shù)語(yǔ):
mounting:表示正在掛接虛擬DOM到真實(shí)DOM。每當(dāng)Clock組件第一次加載到DOM中的時(shí)候,我們都想生成定時(shí)器,
updating:表示正在被重新渲染。
unmounting:表示正在將虛擬DOM移除真實(shí)DOM。每當(dāng)Clock生成的這個(gè)DOM被移除的時(shí)候,我們也會(huì)想要清除定時(shí)器,
Document
再來(lái)一個(gè)例子
Document
1. 當(dāng)正確使用狀態(tài)State被傳入 ReactDOM.render() 時(shí), React 會(huì)調(diào)用 Clock組件的構(gòu)造函數(shù)。 因?yàn)?Clock 要顯示的是當(dāng)前時(shí)間,所以它將使用包含當(dāng)前時(shí)間的對(duì)象來(lái)初始化 this.state 。我們稍后會(huì)更新此狀態(tài)。 2. 然后 React 調(diào)用了 Clock 組件的 render() 方法。 React 從該方法返回內(nèi)容中得到要顯示在屏幕上的內(nèi)容。然后,React 然后更新 DOM 以匹配 Clock 的渲染輸出。 3. 當(dāng) Clock 輸出被插入到 DOM 中時(shí),React 調(diào)用 componentDidMount() 生命周期鉤子。在該方法中,Clock 組件請(qǐng)求瀏覽器設(shè)置一個(gè)定時(shí)器來(lái)一次調(diào)用 tick()。 4. 瀏覽器會(huì)每隔一秒調(diào)用一次 tick()方法。在該方法中, Clock 組件通過(guò) setState() 方法并傳遞一個(gè)包含當(dāng)前時(shí)間的對(duì)象來(lái)安排一個(gè) UI 的更新。通過(guò) setState(), React 得知了組件 state(狀態(tài))的變化, 隨即再次調(diào)用 render() 方法,獲取了當(dāng)前應(yīng)該顯示的內(nèi)容。 這次,render() 方法中的 this.state.date 的值已經(jīng)發(fā)生了改變, 從而,其輸出的內(nèi)容也隨之改變。React 于是據(jù)此對(duì) DOM 進(jìn)行更新。 5. 如果通過(guò)其他操作將 Clock 組件從 DOM 中移除了, React 會(huì)調(diào)用 componentWillUnmount() 生命周期鉤子, 所以計(jì)時(shí)器也會(huì)被停止。
1.不要直接更新狀態(tài)
this.state.comment = "hello";
應(yīng)當(dāng)使用setState()
this.setState({ comment: "hello })
構(gòu)造函數(shù)是唯一初始化this.state的地方
2.狀態(tài)可能是異步的
this.state this.props可能是異步的,我們不能依靠她們的值來(lái)計(jì)算下一個(gè)狀態(tài)。
// 例如: 此代碼可能無(wú)法計(jì)算新的值 this.setState({ counter: this.state.count + this.props.increament })
為了解決這個(gè)問(wèn)題,我們應(yīng)該使用setState的第二種形式來(lái)處理。
this.setState(function(prevState, props) { return { counter: prevState.counter + props.insertment } })
// 使用箭頭函數(shù) this.setState((prevState, props) => ({ counter: prevState.counter + props.insertment }))
3.狀態(tài)更新合并
// 例如: 你的狀態(tài)可能包含一些獨(dú)立的變量 constructor(props) { super(props); this.state = { posts: [], comments: [] }; }
// 我們可以獨(dú)立的更新 componentDidMount() { fetchPosts().then(response => { this.setState({ posts: response.posts }); }); fetchComments().then(response => { this.setState({ comments: response.comments }); }); }
這里的合并是淺合并,也就是說(shuō)this.setState({comments})完整保留了this.state.posts,但完全替換了this.state.comments。
3.數(shù)據(jù)自頂向下流動(dòng)
父子組件都不知道某一個(gè)組件是否有狀態(tài),并且它們不應(yīng)該關(guān)心某一個(gè)組件的狀態(tài),因?yàn)槊恳粋€(gè)狀態(tài)除了擁有它并且設(shè)置它的組件之外,其他的組件是無(wú)法訪問(wèn)到的。
組件可以選擇將其狀態(tài)作為屬性傳遞給其子組件:
這通常被稱為是自頂向下或者是單項(xiàng)數(shù)據(jù)流.任何狀態(tài)始終由某一個(gè)特定的組件所擁有,并且改狀態(tài)導(dǎo)出的任何數(shù)據(jù)只能影響樹中下方的組件
如果你想象一個(gè)組件樹作為屬性的瀑布,每個(gè)組件的狀態(tài)就像一個(gè)額外的水源,它連接在一個(gè)任意點(diǎn),但也流下來(lái)。
4.組件是真正隔離的
function App() { return (); } ReactDOM.render(, document.getElementById("root") );
每一個(gè)clock都會(huì)建立自己的定時(shí)器,并獨(dú)立的更新。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/108356.html
摘要:在構(gòu)造函數(shù)里面初始化的數(shù)據(jù),把數(shù)據(jù)放在頁(yè)面上,點(diǎn)擊時(shí)候調(diào)用方法改變中的數(shù)據(jù)。是中父組件向子組件通信的方式,下面是一個(gè)簡(jiǎn)單的例子使用組件我是顯示的數(shù)據(jù)我們定義組件時(shí)候在構(gòu)造函數(shù)中可以接收到參數(shù),并且要使用傳到的構(gòu)造方法中。 React的學(xué)習(xí)之路還要繼續(xù)走下去,最近一邊在做未完成的項(xiàng)目一邊學(xué)習(xí)React,項(xiàng)目是vue寫的,后面還需要有一個(gè)后臺(tái)管理系統(tǒng)計(jì)劃使用react完成,寒假說(shuō)長(zhǎng)也不長(zhǎng),...
摘要:毫無(wú)疑問(wèn)的是算法的復(fù)雜度與效率是決定能夠帶來(lái)性能提升效果的關(guān)鍵因素。速度略有損失,但可讀性大大提高。因此目前的主流算法趨向一致,在主要思路上,與的方式基本相同。在里面實(shí)現(xiàn)了的算法與支持。是唯一添加的方法所以只發(fā)生在中。 VirtualDOM是react在組件化開發(fā)場(chǎng)景下,針對(duì)DOM重排重繪性能瓶頸作出的重要優(yōu)化方案,而他最具價(jià)值的核心功能是如何識(shí)別并保存新舊節(jié)點(diǎn)數(shù)據(jù)結(jié)構(gòu)之間差異的方法,...
react組件 參考:https://facebook.github.io/re... react的組件是其核心思想部分,react允許將整個(gè)ui設(shè)計(jì)分割稱為獨(dú)立的、可復(fù)用的隔離模塊,react的組件是一個(gè)抽象的類,直接使用reacy.component是沒有很大意義的,所以一般使用的方法就是定義一個(gè) class 來(lái)繼承這個(gè)component,并且需要實(shí)現(xiàn)方法 render();就像下面一樣: ...
react組件 參考:https://facebook.github.io/re... react的組件是其核心思想部分,react允許將整個(gè)ui設(shè)計(jì)分割稱為獨(dú)立的、可復(fù)用的隔離模塊,react的組件是一個(gè)抽象的類,直接使用reacy.component是沒有很大意義的,所以一般使用的方法就是定義一個(gè) class 來(lái)繼承這個(gè)component,并且需要實(shí)現(xiàn)方法 render();就像下面一樣: ...
本篇主要和大家溝通關(guān)于ahooks ,我們可以理解為加深對(duì) React hooks 的了解。 我們先說(shuō)下關(guān)于抽象自定義 hooks。構(gòu)建屬于自己的 React hooks 工具庫(kù)。 其實(shí)我們應(yīng)該培養(yǎng)閱讀學(xué)習(xí)源碼的習(xí)慣,工具庫(kù)是一個(gè)對(duì)源碼閱讀不錯(cuò)的選擇。 注:本系列對(duì) ahooks 的源碼解析是基于v3.3.13。 現(xiàn)在就進(jìn)入主題用ahooks 來(lái)封裝 React要注意的時(shí)機(jī)? Fun...
閱讀 2235·2021-09-22 15:25
閱讀 3618·2019-08-30 12:48
閱讀 2207·2019-08-30 11:25
閱讀 2340·2019-08-30 11:05
閱讀 727·2019-08-29 17:28
閱讀 3288·2019-08-26 12:16
閱讀 2611·2019-08-26 11:31
閱讀 1707·2019-08-23 17:08