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

React組件設計模式之組合組件應用實例分析

 更新時間:2020年04月29日 11:00:31   作者:nero  
這篇文章主要介紹了React組件設計模式之組合組件,結合實例形式分析了React組件設計模式中組合組件相關概念、原理、應用場景與操作注意事項,需要的朋友可以參考下

本文實例講述了React組件設計模式之組合組件應用。分享給大家供大家參考,具體如下:

這種模式本質上解決的是組件之間傳值的問題。但是它對于傳值以及一些內部操控的邏輯封裝得更嚴密。

場景:希望減少上下級組件之間props的傳遞,簡單來說就是不用傳做顯式地傳值,來達到組件之間相互通信的目的

舉例來說,某些界面中應該有Tabs這樣的組件,由Tab和TabItem組成,點擊每個TabItem,該TabItem會高亮,

那么Tab和TabItem自然要進行溝通。很自然的寫法是像下面這樣

<TabItem active={true} onClick={this.onClick}>One</TabItem>
<TabItem active={false} onClick={this.onClick}>Two</TabItem>
<TabItem active={false} onClick={this.onClick}>Three</TabItem>

這樣的缺點很明顯:

  • 每次使用 TabItem 都要傳遞一堆 props
  • 每增加一個新的 TabItem,都要增加對應的 props
  • 如果要增加 TabItem,就要去修改 Tabs 的 JSX 代碼

但是,組件之間的交互我們又不希望通過props或者context來實現。希望用法如下面一樣簡潔。

  <Tabs>
   <TabItem>第一</TabItem>
   <TabItem>第二</TabItem>
   <TabItem>第三</TabItem>
  </Tabs>

組件之間通過隱秘的方式進行通信,但這里的隱秘實際上是對props的操作在一個地方進行管理。

實現

明白了要實現的交互,和代碼層面要實現的效果,就可以開始動手了。

TabItem組件有兩個關鍵的props: active(表明當前是否應高亮),onTabClick(自己被點擊時調用的回調函數),

TabItem由于是每個Tab頁面的容器,它只負責把props.children渲染出來,所以用函數式組件即可。

export const TabItem = props => {
 const { active, onTabClick, children } = props
 const style = {
  color: active ? 'red' : 'green',
  cursor: 'pointer'
 }
 return <>
  <h1 style={style} onClick={onTabClick}>
   {children}
  </h1>
 </>
}

我們再來回顧一下想到達到的效果:

  <Tabs>
   <TabItem>第一</TabItem>
   <TabItem>第二</TabItem>
   <TabItem>第三</TabItem>
  </Tabs>

使用組件時要避免傳遞props的缺點,那么在哪里傳遞呢?自然是是Tabs組件。但上面并沒有傳入props啊。

Tabs 雖然可以訪問到props里邊的children,但是到手的children已經是現成的如果直接改它的話,會出問題。

不可以直接改children的話,我們就把children復制一份,然后改這個復制過來的children,再渲染出去,就ok啦!

下面來看Tabs的實現:

class Tabs extends React.Component {
 state={
  activeIndex: 0
 }
 render() {
  const { activeIndex } = this.state
  const newChildren = React.Children.map(this.props.children, (child, index) => {
   if (child.type) {
     // 復制并修改children
    return React.cloneElement(child, {
     active: activeIndex === index,
     onTabClick: () => this.setState({activeIndex: index})
    })
   } else {
    return child
   }
  })
  return <div className="tabs">
   {newChildren}
  </div>
 }
}

這里需要用到React不常用的api:

  • React.Children.map
  • React.cloneElement

使用React.Children.map來對props.children進行遍歷。

React.cloneElement可以復制某個元素,第一個參數是被復制的元素,第二個參數我們可以把想傳入的props加進去,也就是這個時機,

我們將active和onTabClick傳入。實現最終效果。

總結

這種模式比較好的把復雜邏輯完全封裝起來了,抽象程度更好,比較適合開發(fā)組件開發(fā)者。針對props的擴展性也比較好,對于使用組件的開發(fā)者來說,也比較友好。

希望本文所述對大家react程序設計有所幫助。

相關文章

  • react如何添加less環(huán)境配置

    react如何添加less環(huán)境配置

    這篇文章主要介紹了react如何添加less環(huán)境配置,本文給大家分享遇到問題及解決方案,結合示例代碼圖文給大家介紹的非常詳細,需要的朋友參考下吧
    2022-05-05
  • 詳解React 的幾種條件渲染以及選擇

    詳解React 的幾種條件渲染以及選擇

    這篇文章主要介紹了詳解React 的幾種條件渲染以及選擇,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • 基于Webpack5 Module Federation的業(yè)務解耦實踐示例

    基于Webpack5 Module Federation的業(yè)務解耦實踐示例

    這篇文章主要為大家介紹了基于Webpack5 Module Federation的業(yè)務解耦實踐示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • react實現路由動畫跳轉功能

    react實現路由動畫跳轉功能

    這篇文章主要介紹了react路由動畫跳轉功能,大概思路是下載第三方庫?引用,創(chuàng)建css文件引用,想要實現跳轉動畫功能,就在那個組件的根節(jié)點綁定classname屬性即可,在跳轉的時候即可實現,需要的朋友可以參考下
    2023-10-10
  • React錯誤的習慣用法分析詳解

    React錯誤的習慣用法分析詳解

    這篇文章主要為大家介紹了React錯誤用法習慣分析詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • React Fiber構建beginWork源碼解析

    React Fiber構建beginWork源碼解析

    這篇文章主要為大家介紹了React Fiber構建beginWork源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • ahooks正式發(fā)布React?Hooks工具庫

    ahooks正式發(fā)布React?Hooks工具庫

    這篇文章主要為大家介紹了ahooks正式發(fā)布值得擁有的React?Hooks工具庫使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • 封裝一個最簡單ErrorBoundary組件處理react異常

    封裝一個最簡單ErrorBoundary組件處理react異常

    這篇文章主要介紹了一個處理react異常的ErrorBoundary組件,簡單實用,代碼詳細,對這個組件感興趣的朋友可以參考下
    2021-04-04
  • React?中使用?react-i18next?國際化的過程(react-i18next?的基本用法)

    React?中使用?react-i18next?國際化的過程(react-i18next?的基本用法)

    i18next?是一款強大的國際化框架,react-i18next?是基于?i18next?適用于?React?的框架,本文介紹了?react-i18next?的基本用法,如果更特殊的需求,文章開頭的官方地址可以找到答案
    2023-01-01
  • 歸納總結Remix?表單常用方法及示例詳解

    歸納總結Remix?表單常用方法及示例詳解

    這篇文章主要為大家歸納總結了Remix?表單常用方法及示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03

最新評論