React的Props、生命周期詳解
Props 的只讀性
“Props” 是 React 中用于傳遞數(shù)據(jù)給組件的一種機(jī)制,通常作為組件的參數(shù)進(jìn)行傳遞。在 React 中,props 是只讀的,意味著一旦將數(shù)據(jù)傳遞給組件的 props,組件就不能直接修改這些 props 的值。所以組件無論是使用函數(shù)聲明還是通過 class 聲明,都決不能修改自身的 props。
所以React有一個嚴(yán)格的規(guī)則:所有 React 組件都必須像純函數(shù)一樣保護(hù)它們的 props 不被更改。
為什么Props是只讀的呢?
當(dāng)我們在父組件中將數(shù)據(jù)傳遞給子組件時,子組件只能使用這些 props 來讀取數(shù)據(jù),而不能修改它們。這是為了確保數(shù)據(jù)的單向流動,使得數(shù)據(jù)的流動更加可控和可預(yù)測。當(dāng) Props 是只讀的時候,我們可以確保數(shù)據(jù)只能從父組件流向子組件,而子組件不能直接修改父組件傳遞的數(shù)據(jù)。這種單向數(shù)據(jù)流有助于維護(hù)組件的可預(yù)測性和代碼的可維護(hù)性。
如果我無法避免要在組件內(nèi)部修改數(shù)據(jù),該怎么辦?
如果你需要在組件內(nèi)部修改數(shù)據(jù),你可以使用組件的狀態(tài)(state)。狀態(tài)是組件內(nèi)部的可變數(shù)據(jù),可以通過特定的方法來修改。但是這些狀態(tài)無法直接傳遞給其他組件,如果需要在多個組件之間共享數(shù)據(jù),可以考慮使用上層組件的狀態(tài)或者全局狀態(tài)管理工具(如 Redux)
代碼示例:
import React, { useState } from 'react'; function ParentComponent() { const [count, setCount] = useState(0); const incrementCount = () => { setCount(count + 1); }; return ( <div> <h2>父組件</h2> <p>Count: {count}</p> <ChildComponent count={count} increment={incrementCount} /> </div> ); } function ChildComponent(props) { return ( <div> <h2>子組件t</h2> <p>總和: {props.count}</p> <button onClick={props.increment}>+1</button> </div> ); } export default ParentComponent;
如何將函數(shù)組件轉(zhuǎn)換成 class 組件 創(chuàng)建一個同名的 ES6 class,并且繼承于 React.Component
。
- 添加一個空的
render()
方法。 - 將函數(shù)體移動到
render()
方法之中。 - 在
render()
方法中使用this.props
替換props
。 - 刪除剩余的空函數(shù)聲明。
函數(shù)式組件
function tick(Props) { const element = ( <div> <h1>Hello, world!</h1> <h2>It is {Props.time.toLocaleTimeString()}.</h2> </div> ); root.render(element); }
class組件
class Clock extends React.Component { render() { return ( <div> <h1>Hello, world!</h1> <h2>It is {this.props.date.toLocaleTimeString()}.</h2> </div> ); } }
生命周期
掛載
- constructor--------組件實(shí)例化時執(zhí)行,用于初始化state和綁定事件等操作
- getDerivedStateFromProps --------在render方法執(zhí)行之前調(diào)用,用于根據(jù)props設(shè)置state。
- render--------渲染組件
- componentDidMount(-------組件掛載到DOM后執(zhí)行,用于執(zhí)行一些需要DOM的操作,如獲取數(shù)據(jù)。
更新
- getDerivedStateFromProps-------在render方法執(zhí)行之前調(diào)用,用于根據(jù)props設(shè)置state
- shouldComponentUpdate------判斷組件是否需要重新渲染,默認(rèn)返回true
- render------渲染組件
- getSnapshotBeforeUpdate------在更新前獲取DOM信息,如滾動位置等。
- componentDidUpdate--------組件更新后執(zhí)行,用于執(zhí)行一些需要DOM的操作,如更新數(shù)據(jù)
卸載
- componentWillUnmount------組件從DOM中移除時經(jīng)歷的階段
寫一個時鐘案例,每秒都會更新時間
class Clock extends React.Component { constructor(props) { super(props); this.state = {date: new Date()}; } componentDidMount() { this.timerID = setInterval( () => this.tick(), 1000 ); } componentWillUnmount() { clearInterval(this.timerID); } tick() { this.setState({ date: new Date() }); } render() { return ( <div> <h1>Hello, world!</h1> <h2>It is {this.state.date.toLocaleTimeString()}.</h2> </div> ); } } const root = ReactDOM.createRoot(document.getElementById('root')); root.render(<Clock />);
讓我們來快速概括一下發(fā)生了什么和這些方法的調(diào)用順序:
- 當(dāng)
<Clock />
被傳給root.render()
的時候,React 會調(diào)用Clock
組件的構(gòu)造函數(shù)。因?yàn)?Clock 需要顯示當(dāng)前的時間,所以它會用一個包含當(dāng)前時間的對象來初始化this.state
。我們會在之后更新 state。 - 之后 React 會調(diào)用組件的
render()
方法。這就是 React 確定該在頁面上展示什么的方式。然后 React 更新 DOM 來匹配Clock
渲染的輸出。 - 當(dāng)
Clock
的輸出被插入到 DOM 中后,React 就會調(diào)用ComponentDidMount()
生命周期方法。在這個方法中,Clock 組件向?yàn)g覽器請求設(shè)置一個計時器來每秒調(diào)用一次組件的tick()
方法。 - 瀏覽器每秒都會調(diào)用一次
tick()
方法。 在這方法之中,Clock
組件會通過調(diào)用setState()
來計劃進(jìn)行一次 UI 更新。得益于setState()
的調(diào)用,React 能夠知道state
已經(jīng)改變了,然后會重新調(diào)用render()
方法來確定頁面上該顯示什么。這一次,render()
方法中的this.state.date
就不一樣了,如此一來就會渲染輸出更新過的時間。 - React 也會相應(yīng)的更新 DOM。一旦 Clock 組件從 DOM 中被移除,React 就會調(diào)用
componentWillUnmount()
生命周期方法,這樣計時器就停止了。
到此這篇關(guān)于React的Props、生命周期的文章就介紹到這了,更多相關(guān)React的Props、生命周期內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
react-router?v6實(shí)現(xiàn)動態(tài)路由實(shí)例
這篇文章主要為大家介紹了react-router?v6實(shí)現(xiàn)動態(tài)路由實(shí)例詳解,<BR>有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08React 模塊聯(lián)邦多模塊項(xiàng)目實(shí)戰(zhàn)詳解
這篇文章主要介紹了React 模塊聯(lián)邦多模塊項(xiàng)目實(shí)戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10react?路由權(quán)限動態(tài)菜單方案配置react-router-auth-plus
這篇文章主要為大家介紹了react路由權(quán)限動態(tài)菜單方案react-router-auth-plus傻瓜式配置詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08React中使用async validator進(jìn)行表單驗(yàn)證的實(shí)例代碼
react上進(jìn)行表單驗(yàn)證是很繁瑣的,在這里使用async-validator處理起來就變的很方便了,接下來通過本文給大家介紹React中使用async validator進(jìn)行表單驗(yàn)證的方法,需要的朋友可以參考下2018-08-08react-router-dom?v6?使用詳細(xì)示例
這篇文章主要介紹了react-router-dom?v6使用詳細(xì)示例,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下,希望對你的學(xué)習(xí)有所幫助2022-09-09