欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React的Props、生命周期詳解

 更新時間:2024年06月28日 09:40:43   作者:zayyo  
“Props” 是 React 中用于傳遞數(shù)據(jù)給組件的一種機(jī)制,通常作為組件的參數(shù)進(jìn)行傳遞,在 React 中,props 是只讀的,意味著一旦將數(shù)據(jù)傳遞給組件的 props,組件就不能直接修改這些 props 的值,這篇文章主要介紹了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)歷的階段

image.png

寫一個時鐘案例,每秒都會更新時間

    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í)例

    這篇文章主要為大家介紹了react-router?v6實(shí)現(xiàn)動態(tài)路由實(shí)例詳解,<BR>有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • React 實(shí)現(xiàn)表單組件的示例代碼

    React 實(shí)現(xiàn)表單組件的示例代碼

    本文主要介紹了React 實(shí)現(xiàn)表單組件的示例代碼,支持包括輸入狀態(tài)管理,表單驗(yàn)證,錯誤信息展示,表單提交,動態(tài)表單元素等功能,具有一定的參考價值,感興趣的可以了解一下
    2024-07-07
  • React 模塊聯(lián)邦多模塊項(xiàng)目實(shí)戰(zhàn)詳解

    React 模塊聯(lián)邦多模塊項(xiàng)目實(shí)戰(zhàn)詳解

    這篇文章主要介紹了React 模塊聯(lián)邦多模塊項(xiàng)目實(shí)戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • 詳解超簡單的react服務(wù)器渲染(ssr)入坑指南

    詳解超簡單的react服務(wù)器渲染(ssr)入坑指南

    這篇文章主要介紹了詳解超簡單的react服務(wù)器渲染(ssr)入坑指南,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-02-02
  • 詳解React?Native中如何使用自定義的引用路徑

    詳解React?Native中如何使用自定義的引用路徑

    這篇文章主要為大家介紹了React?Native中如何使用自定義的引用路徑詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • react?路由權(quán)限動態(tài)菜單方案配置react-router-auth-plus

    react?路由權(quán)限動態(tài)菜單方案配置react-router-auth-plus

    這篇文章主要為大家介紹了react路由權(quán)限動態(tài)菜單方案react-router-auth-plus傻瓜式配置詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • 詳解如何在Remix 中使用 tailwindcss

    詳解如何在Remix 中使用 tailwindcss

    這篇文章主要為大家介紹了如何在Remix中使用tailwindcss方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • React?diff算法超詳細(xì)講解

    React?diff算法超詳細(xì)講解

    渲染真實(shí)DOM的開銷很大,有時候我們修改了某個數(shù)據(jù),直接渲染到真實(shí)dom上會引起整個dom樹的重繪和重排。我們希望只更新我們修改的那一小塊dom,而不是整個dom,diff算法就幫我們實(shí)現(xiàn)了這點(diǎn)。diff算法的本質(zhì)就是:找出兩個對象之間的差異,目的是盡可能做到節(jié)點(diǎn)復(fù)用
    2022-11-11
  • React中使用async validator進(jìn)行表單驗(yàn)證的實(shí)例代碼

    React中使用async validator進(jìn)行表單驗(yàn)證的實(shí)例代碼

    react上進(jìn)行表單驗(yàn)證是很繁瑣的,在這里使用async-validator處理起來就變的很方便了,接下來通過本文給大家介紹React中使用async validator進(jìn)行表單驗(yàn)證的方法,需要的朋友可以參考下
    2018-08-08
  • react-router-dom?v6?使用詳細(xì)示例

    react-router-dom?v6?使用詳細(xì)示例

    這篇文章主要介紹了react-router-dom?v6使用詳細(xì)示例,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下,希望對你的學(xué)習(xí)有所幫助
    2022-09-09

最新評論