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

React如何創(chuàng)建組件

 更新時間:2021年06月27日 15:29:34   作者:小和山的菜鳥們  
本文我們將介紹 React中組件的類別,以及如何創(chuàng)建和使用組件。具有一定的參考價值,感興趣的小伙伴們可以參考一下

前言

這節(jié)我們將介紹 React 中組件的類別,以及如何創(chuàng)建和使用組件。

本文會向你介紹以下內(nèi)容:

  • 創(chuàng)建類組件
  • 創(chuàng)建函數(shù)組件
  • 渲染組件
  • 合成組件
  • 提取組件
  • Props 是只讀的

組件介紹

組件(Components) 讓你可以將用戶界面分成獨立的,可復(fù)用的小部件,并可以對每個部件進行單獨的設(shè)計。

從定義上來說, 組件就像JavaScript的函數(shù)。組件可以接收任意輸入(稱為”props”), 并返回 React 元素,用以描述屏幕顯示內(nèi)容。

Props , 即屬性(Property), 在代碼中寫作 props,故可用 props 指代 properties。
react中有兩種組件:類組件(class components)、函數(shù)組件(function components)

創(chuàng)建類組件

類組件的定義有如下要求:

  • 類組件需要繼承自 React.Component
  • 類組件必須實現(xiàn)render函數(shù)

在ES6之前,可以通過create-react-class 模塊來定義類組件,但是目前官網(wǎng)建議我們使用ES6的class類定義。

使用class定義一個組件:

class App extends Component {
  constructor() {
    super()
    this.state = {}
  }

  render() {
    return <h2>Hello App</h2>
  }
}

我們來詳細分析一下類組件有哪幾個部分

  • constructor:這是類組件的構(gòu)造函數(shù),是可選的,我們通常在constructor中初始化一些數(shù)據(jù);
  • this.state:我們在constructor中給類組件加入state屬性,你可以理解為組件中有一個state對象,其中包含著各種屬性,用于維護組件內(nèi)部的數(shù)據(jù)。同時你可以通過this.state.<屬性名>訪問該屬性;
  • render(): 該方法是 class 組件中唯一必須實現(xiàn)的方法,類組件通過render()返回組件的顯示內(nèi)容;

關(guān)于 state

我們可以通過this.state給類組件添加數(shù)據(jù)對象,我們可以通過this.state.<屬性名>去訪問我們setState中的屬性。

constructor(props) {
    super(props);
    this.state = {
      name:"xhs-rookies"
    }
  }

render(){
    return <h2>{this.state.name}</h2>
  }

但是我們想要修改上述例子中的name屬性的時候,則必須通過react給我們規(guī)定好的setState()方法,去給state添加或者修改其中的數(shù)值。

this.state.name = 'new xhs-rookies' //錯誤的方式,不允許采用
this.setState({ name: 'new xhs-rookies' }) //正確的方式

簡單點來說,在 react 中頁面是通過數(shù)據(jù)進行渲染,使用setState()更新的數(shù)據(jù),react 會幫我們執(zhí)行render()去更新頁面,從而將頁面中用到 state 中的數(shù)據(jù)全部更新。

關(guān)于 render

當(dāng) render 被調(diào)用時,它會檢查 this.props 和 this.state 的變化并返回很多類型,很多時候我們選擇讓該方法返回 React 元素,然后交由 React 去渲染展示:

React 元素:

  • 通常通過 JSX 創(chuàng)建。
  • 例如,<div/> 會被 React 渲染為 DOM 節(jié)點,<MyComponent/> 會被 React 渲染為自定義組件;
  • 無論是 <div/> 還是 <MyComponent/> 均為 React 元素。

詳細關(guān)于 render() 方法的內(nèi)容請見React.Component - Render)

創(chuàng)建函數(shù)組件

函數(shù)組件是使用 function 來進行定義的函數(shù),只是這個函數(shù)會返回和類組件中 render 函數(shù)返回一樣的內(nèi)容。

跟類組件相比,函數(shù)組件有自己的特點:

  • 沒有生命周期,也會被更新并掛載,但是沒有生命周期函數(shù);
  • 沒有 this(組件實例);
  • 沒有內(nèi)部狀態(tài)(state);

我們來定義一個函數(shù)組件:

export default function App() {
  return <div>xhs rookies</div>
}

渲染組件

在前幾篇中, 我們只遇到代表 DOM 標(biāo)簽的 React 元素:

const element = <div />

然而,元素也可以代表用戶定義的組件:

const element = <Welcome name="xhs rookies" />

當(dāng) React 遇到一個代表用戶定義組件的元素時,它將 JSX 屬性以一個單獨對象的形式傳遞給相應(yīng)的組件。 我們將其稱為 “props” 對象。

比如, 以下代碼在頁面上渲染“xhs rookies”:

function Welcome(props) {
  return <h1>Hello, {props.name}</h1>
}

const element = <Welcome name="xhs rookies" />
ReactDOM.render(element, document.getElementById('root'))

我們簡單解釋一下上面這個例子:

  • 我們調(diào)用了 ReactDOM.render() 方法并向其中傳入了 <Welcome name="xhs rookies" /> 元素。
  • React 調(diào)用 Welcome 組件,并向其中傳入了 {name: 'xhs rookies'} 作為 props 對象。
  • Welcome 組件返回 <h1>xhs rookies</h1>。
  • React DOM 迅速更新 DOM ,使其顯示為 <h1>xhs rookies</h1>。

注意: 組件名稱總是以大寫字母開始。

舉例來說, <div/> 代表一個 DOM 標(biāo)簽,而 <Welcome/> 則代表一個組件,并且需要在作用域中有一個 Welcome 組件。

你可以深入 JSX閱讀更多關(guān)于這點背后的原因。

合成組件

組件可以在它們的輸出中引用其它組件。這使得我們可以使用同樣的組件來抽象到任意層級。一個按鈕,一個表單,一個對話框,一個屏幕:在 React 應(yīng)用中,所有這些都通常描述為組件。

例如,我們可以創(chuàng)建一個 App 組件,并在其內(nèi)部多次渲染 Welcome:

function Welcome(props) {
  return <h1>Hello, {props.name}</h1>
}

function App() {
  return (
    <div>
      <Welcome name="rookie-Sara" />
      <Welcome name="rookie-Cahal" />
      <Welcome name="rookie-Edite" />
    </div>
  )
}

 
ReactDOM.render(<App />, document.getElementById('root'))

通常,新的 React apps 都有一個單獨的頂層 App 組件。然而,如果你在已有的應(yīng)用中整合 React,你可以需要由下至上地, 從類似于 Button 這樣的小組件開始, 逐漸整合到視圖層的頂層。

提取組件

不要害怕把一個組件分為多個更小的組件。

舉個例子,思考下名 Comment 組件:

function Comment(props) {
  return (
    <div className="Comment">
      <div className="UserInfo">
        <img className="Avatar" src={props.author.avatarUrl} alt={props.author.name} />
        <div className="UserInfo-name">{props.author.name}</div>
      </div>
      <div className="Comment-text">{props.text}</div>
      <div className="Comment-date">{formatDate(props.date)}</div>
    </div>
  )
}

它接受 author(一個對象),text(一個字符串)和 date(一個日期)作為 props。

這個組件修改起來很麻煩,因為它是被嵌套的,而且很難復(fù)用其中的某個部分。讓我們從其中提取一些組件。

首先,提取頭像 Avatar:

function Avatar(props) {
  return <img className="Avatar" src={props.user.avatarUrl} alt={props.user.name} />
}

Avatar 組件不用關(guān)心它在 Comment 中是如何渲染的。這是為什么我們它的 prop 一個更通用的屬性名: user, 而不是 author 的原因。

我們建議從組件本身的角度來命名 props 而不是它被使用的上下文環(huán)境。

我們可以稍微簡化一下 Comment 組件:

function Comment(props) {
  return (
    <div className="Comment">
      <div className="UserInfo">
        <Avatar user={props.author} />
        <div className="UserInfo-name">{props.author.name}</div>
      </div>
      <div className="Comment-text">{props.text}</div>
      <div className="Comment-date">{formatDate(props.date)}</div>
    </div>
  )
}

接下來,我們提取用戶信息 UserInfo 組件, 用于將 Avatar 顯示在用戶名旁邊:

function UserInfo(props) {
  return (
    <div className="UserInfo">
      <Avatar user={props.user} />
      <div className="UserInfo-name">{props.user.name}</div>
    </div>
  )
}

這使我們可以進一步簡化 Comment 組件:

function Comment(props) {
  return (
    <div className="Comment">
      <UserInfo user={props.author} />
      <div className="Comment-text">{props.text}</div>
      <div className="Comment-date">{formatDate(props.date)}</div>
    </div>
  )
}

提取組件可能看起來是一個繁瑣的工作,但是在大型的 Apps 中可以回報給我們的是大量的可復(fù)用組件。一個好的經(jīng)驗準(zhǔn)則是如果你 UI 的一部分需要用多次 (Button,Panel,Avatar),或者本身足夠復(fù)雜(App,F(xiàn)eedStory,Comment),最好的做法是使其成為可復(fù)用組件。

Props 是只讀的

無論你用函數(shù)或類的方法來聲明組件, 它都無法修改其自身 props. 思考下列 sum (求和)函數(shù):

function sum(a, b) {
  return a + b
}

這種函數(shù)稱為 “純函數(shù)” ,因為它們不會試圖改變它們的輸入,并且對于同樣的輸入,始終可以得到相同的結(jié)果。

反之, 以下是非純函數(shù), 因為它改變了自身的輸入值:

function withdraw(account, amount) {
  account.total -= amount
}

雖然 React 很靈活,但是它有一條嚴(yán)格的規(guī)則:

注意: 所有 React 組件都必須是純函數(shù),并禁止修改其自身 props 。
當(dāng)然, 應(yīng)用 UI 總是動態(tài)的,并且隨時有可以改變。

如果我們想要動態(tài)改變 UI,那么就會涉及到我們上面說到的state(狀態(tài)) 。我們通過動態(tài)的改變state來渲染整個頁面,我們后面會提及,詳情見 深入理解 setState

到此這篇關(guān)于React如何創(chuàng)建組件的文章就介紹到這了,更多相關(guān)React 創(chuàng)建組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React 組件的狀態(tài)下移和內(nèi)容提升的操作方法

    React 組件的狀態(tài)下移和內(nèi)容提升的操作方法

    這篇文章主要介紹了React 組件的狀態(tài)下移和內(nèi)容提升,通過代碼講解了渲染性能的組件問題結(jié)合實例代碼給大家講解的非常詳細,需要的朋友可以參考下
    2022-11-11
  • React渲染的優(yōu)化方案

    React渲染的優(yōu)化方案

    react的渲染機制是非常獨特的,有別于 Vue 框架的渲染次數(shù)的優(yōu)化計算,React 很久以來就有PureComponent、shouldUpdate,本文小編給大家介紹了React渲染的優(yōu)化方案,需要的朋友可以參考下
    2024-08-08
  • 在?React?項目中全量使用?Hooks的方法

    在?React?項目中全量使用?Hooks的方法

    這篇文章主要介紹了在?React?項目中全量使用?Hooks,使用 Hooks 能為開發(fā)提升不少效率,但并不代表就要拋棄 Class Component,依舊還有很多場景我們還得用到它,本文給大家介紹的非常詳細,需要的朋友可以參考下
    2022-10-10
  • react跳轉(zhuǎn)后路由變了頁面沒刷新的解決

    react跳轉(zhuǎn)后路由變了頁面沒刷新的解決

    這篇文章主要介紹了react跳轉(zhuǎn)后路由變了頁面沒刷新的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • React onClick/onChange傳參(bind綁定)問題

    React onClick/onChange傳參(bind綁定)問題

    這篇文章主要介紹了React onClick/onChange傳參(bind綁定)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 解決React報錯React?Hook?useEffect?has?a?missing?dependency

    解決React報錯React?Hook?useEffect?has?a?missing?dependency

    這篇文章主要為大家介紹了解決React報錯React?Hook?useEffect?has?a?missing?dependency,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • React實現(xiàn)Excel文件的導(dǎo)出與在線預(yù)覽功能

    React實現(xiàn)Excel文件的導(dǎo)出與在線預(yù)覽功能

    這篇文章主要為大家詳細介紹了如何利用?React?18?的強大功能,演示如何使用?React?18?編寫?Excel?文件的導(dǎo)出與在線預(yù)覽功能,需要的小伙伴可以參考下
    2023-12-12
  • React Store及store持久化的使用教程

    React Store及store持久化的使用教程

    這篇文章主要介紹了React Store及store持久化的使用教程,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01
  • React實現(xiàn)歌詞滾動效果(跟隨音樂播放時間滾動)

    React實現(xiàn)歌詞滾動效果(跟隨音樂播放時間滾動)

    這篇文章主要為大家詳細介紹了React實現(xiàn)歌詞滾動效果(跟隨音樂播放使勁按滾動),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2024-02-02
  • ReactNative列表ListView的用法

    ReactNative列表ListView的用法

    本篇文章主要介紹了ReactNative列表ListView的用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08

最新評論