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

React構(gòu)建組件的幾種方式及區(qū)別

 更新時間:2022年08月08日 10:15:45   作者:nine99  
這篇文章主要介紹了React構(gòu)建組件的幾種方式及區(qū)別,組件就是把圖形、非圖形的各種邏輯均抽象為一個統(tǒng)一的概念來實現(xiàn)開發(fā)的模式文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下

一、組件是什么

組件就是把圖形、非圖形的各種邏輯均抽象為一個統(tǒng)一的概念(組件)來實現(xiàn)開發(fā)的模式

React中,一個類、一個函數(shù)都可以視為一個組件

組件所存在的優(yōu)勢:

  • 降低整個系統(tǒng)的耦合度,在保持接口不變的情況下,我們可以替換不同的組件快速完成需求,例如輸入框,可以替換為日歷、時間、范圍等組件作具體的實現(xiàn)
  • 調(diào)試方便,由于整個系統(tǒng)是通過組件組合起來的,在出現(xiàn)問題的時候,可以用排除法直接移除組件,或者根據(jù)報錯的組件快速定位問題,之所以能夠快速定位,是因為每個組件之間低耦合,職責單一,所以邏輯會比分析整個系統(tǒng)要簡單
  • 提高可維護性,由于每個組件的職責單一,并且組件在系統(tǒng)中是被復用的,所以對代碼進行優(yōu)化可獲得系統(tǒng)的整體升級

二、如何構(gòu)建

React目前來講,組件的創(chuàng)建主要分成了三種方式:

  • 函數(shù)式創(chuàng)建
  • 通過 React.createClass 方法創(chuàng)建
  • 繼承 React.Component 創(chuàng)建

函數(shù)式創(chuàng)建

React Hooks出來之前,函數(shù)式組件可以視為無狀態(tài)組件,只負責根據(jù)傳入的props來展示視圖,不涉及對state狀態(tài)的操作

大多數(shù)組件可以寫為無狀態(tài)組件,通過簡單組合構(gòu)建其他組件

React中,通過函數(shù)簡單創(chuàng)建組件的示例如下:

function HelloComponent(props, /* context */) {
  return <div>Hello {props.name}</div>
}

通過 React.createClass 方法創(chuàng)建

React.createClass是react剛開始推薦的創(chuàng)建組件的方式,目前這種創(chuàng)建方式已經(jīng)不怎么用了

像上述通過函數(shù)式創(chuàng)建的組件的方式,最終會通過babel轉(zhuǎn)化成React.createClass這種形式,

轉(zhuǎn)化成如下:

function HelloComponent(props) /* context */{
  return React.createElement(
    "div",
    null,
    "Hello ",
    props.name
  );
}

由于上述的編寫方式過于冗雜,目前基本上不使用上

繼承 React.Component 創(chuàng)建

同樣在react hooks出來之前,有狀態(tài)的組件只能通過繼承React.Component這種形式進行創(chuàng)建

有狀態(tài)的組件也就是組件內(nèi)部存在維護的數(shù)據(jù),在類創(chuàng)建的方式中通過this.state進行訪問

當調(diào)用this.setState修改組件的狀態(tài)時,組價會再次會調(diào)用render()方法進行重新渲染

通過繼承React.Component創(chuàng)建一個時鐘示例如下:

class Timer extends React.Component {
  constructor(props) {
    super(props);
    this.state = { seconds: 0 };
  }

  tick() {
    this.setState(state => ({
      seconds: state.seconds + 1
    }));
  }

  componentDidMount() {
    this.interval = setInterval(() => this.tick(), 1000);
  }

  componentWillUnmount() {
    clearInterval(this.interval);
  }

  render() {
    return (
      <div>
        Seconds: {this.state.seconds}
      </div>
    );
  }
}

三、區(qū)別

由于React.createClass創(chuàng)建的方式過于冗雜,并不建議使用

而像函數(shù)式創(chuàng)建和類組件創(chuàng)建的區(qū)別主要在于需要創(chuàng)建的組件是否需要為有狀態(tài)組件:

  • 對于一些無狀態(tài)的組件創(chuàng)建,建議使用函數(shù)式創(chuàng)建的方式
  • 由于react hooks的出現(xiàn),函數(shù)式組件創(chuàng)建的組件通過使用hooks方法也能使之成為有狀態(tài)組件,再加上目前推崇函數(shù)式編程,所以這里建議都使用函數(shù)式的方式來創(chuàng)建組件

在考慮組件的選擇原則上,能用無狀態(tài)組件則用無狀態(tài)組件

到此這篇關于React構(gòu)建組件的幾種方式及區(qū)別的文章就介紹到這了,更多相關React構(gòu)建組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • React手寫一個手風琴組件示例

    React手寫一個手風琴組件示例

    這篇文章主要為大家介紹了React手寫一個手風琴組件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • 字節(jié)封裝React組件手機號自動校驗格式FormItem

    字節(jié)封裝React組件手機號自動校驗格式FormItem

    這篇文章主要為大家介紹了字節(jié)封裝React組件手機號自動校驗格式FormItem,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • react創(chuàng)建項目啟動報錯的完美解決方法

    react創(chuàng)建項目啟動報錯的完美解決方法

    這篇文章主要介紹了react創(chuàng)建項目啟動報錯的完美解決方法,全稱為Node Package Manager,是隨同NodeJS一起安裝的包管理工具,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • React根據(jù)寬度自適應高度的示例代碼

    React根據(jù)寬度自適應高度的示例代碼

    本篇文章主要介紹了React根據(jù)寬度自適應高度的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • react源碼層分析協(xié)調(diào)與調(diào)度

    react源碼層分析協(xié)調(diào)與調(diào)度

    本文主要介紹了深入理解React協(xié)調(diào)與調(diào)度(Scheduler)原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-10-10
  • react-navigation之動態(tài)修改title的內(nèi)容

    react-navigation之動態(tài)修改title的內(nèi)容

    這篇文章主要介紹了react-navigation之動態(tài)修改title的內(nèi)容,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • 詳解三種方式在React中解決綁定this的作用域問題并傳參

    詳解三種方式在React中解決綁定this的作用域問題并傳參

    這篇文章主要介紹了詳解三種方式在React中解決綁定this的作用域問題并傳參,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08
  • React使用Electron開發(fā)桌面端的詳細流程步驟

    React使用Electron開發(fā)桌面端的詳細流程步驟

    React是一個流行的JavaScript庫,用于構(gòu)建Web應用程序,結(jié)合Electron框架,可以輕松地將React應用程序打包為桌面應用程序,本文詳細介紹了使用React和Electron開發(fā)桌面應用程序的步驟,需要的朋友可以參考下
    2023-06-06
  • React immer與Redux Toolkit使用教程詳解

    React immer與Redux Toolkit使用教程詳解

    這篇文章主要介紹了React中immer與Redux Toolkit的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-10-10
  • React避坑指南之useEffect 依賴引用類型問題分析

    React避坑指南之useEffect 依賴引用類型問題分析

    這篇文章主要介紹了React避坑指南之useEffect 依賴引用類型問題分析,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03

最新評論