12 組合與繼承、CSS Module

組合與繼承

  1. 若Container內部有內容,React會在props內部增加children屬性
  2. 若Container內部有非元素內容,children:非元素內容
  3. 若Container內部有單個元素內容,children:React元素對象
  4. 若Container內部有多個元素內容,children:[]
  • 打印props
  • 情況2:非元素內容
<Container>666</Container>

在這里插入圖片描述

  • 情況3:單個元素內容
<Container><h1>666</h1></Container>

在這里插入圖片描述

  • 情況4:多個元素內容
<Container><h1>666</h1><p>888</p>
</Container>

在這里插入圖片描述

props

  • JSX還可以通過props傳遞視圖元素
  • JSX本質上都會轉成React元素(對象 Object)
  • 視圖通過props傳遞的機制類似Vue的插槽,但React沒有slot的概念定義
  • React本身就允許通過props傳遞任何類型的數據到子組件

React樣式

  • CSS Module
  • index.module.css
import styles from './index4.module.css'
// 用變量接收
class Container extends React.Component {render() {console.log(this.props)return (<div className={styles.container}><div className={styles.header}>{this.props.header}</div><div className={styles.main}><div className={styles.left}>{this.props.left}</div><div className={styles.right}>{this.props.right}</div></div></div>)}
}
class Header extends React.Component {render() {return <div>Header</div>}
}
class Left extends React.Component {render() {return <div>Left</div>}
}
class Right extends React.Component {render() {return <div>Right</div>}
}
class App extends React.Component {render() {return (<div><Containerheader={<Header />}left={<Left />}right={<Right />}></Container></div>)}
}
ReactDOM.render(<App />,document.getElementById('app')
)
.container {background: #ccc;text-align: center;
}
.header {height: 50px;line-height: 50px;border: 2px dashed #000;
}
.main {display: flex;
}
.left {width: 20%;background: pink;
}
.right {background: skyblue;flex: 1;
}

多層組合

import styles from './index5.module.css'// 多層組合
// Modal是公共的部分,定制的內容作為children傳入
function Modal(props) {return (<div className={styles.wrap}><header className={styles.title}>{props.title}</header><div className="main">{props.children}</div></div>)
}
// 注意函數式 props作為參數傳入 不用this來訪問props
function Alert(props) {return (<div><Modal title={props.title}><p>{props.mainText}</p></Modal></div>)
}
function LoginModal(props) {return (<div><Modal title={props.title}><form><p>用戶名:<input type="text" /></p><p>密碼:<input type="password" /></p><p><button>登錄</button></p></form></Modal></div>)
}
ReactDOM.render(<div><AlertmainText="顯示內容"title="顯示modal"/><LoginModal title="登錄modal"></LoginModal></div>,document.getElementById('app'))

React目前還沒有發現有需要組件繼承的需求
因為通過children或者傳遞視圖React元素的方式完全可以解決組件組合的問題太;
props可以傳遞任何類型的數據,所以組合的方式可以替代繼承方案。
邏輯部分需要繼承或共用:該部分需要自己去編寫邏輯抽離的模塊、函數、類,單獨進行模塊導入使用

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/250882.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/250882.shtml
英文地址,請注明出處:http://en.pswp.cn/news/250882.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

工具分享 --- tinyPNG,大圖片壓縮工具

今天自己的寫的項目跑在了遠程服務器上… 圖片加載的速度讓人難以接受, 于是各種百度找到了一個在線找到了個圖片壓縮的網站 TinyPNG 可以看一下壓縮的效果…真心不錯啊… 網站如下: https://tinypng.com 額…有些大于5M的需要錢,才能壓縮… 用系統畫圖工具…貌似也能壓縮… …

Mysql 忘記管理員密碼更改

對管理員設置密碼第一種方式&#xff1a;#mysqladmin -u root password new-password;#mysqladmin -u root -h localhost password new-password;mysql的選項可以不帶空格&#xff0c;有時候帶空格是錯 第二種方式&#xff1a; set password for rootlocahostPASSWORED(); 第三…

ironic如何支持部署時按需RAID?

ironic如何支持部署時按需RAID&#xff1f; 新浪大神推薦使用element proliant-tools制作deploy image。element proliant-tools會在ipa ramdisk中安裝一個rpm包hpssacli&#xff08;HP的RAID管理工具&#xff09;&#xff0c;和一個python module proliantutils&#xff08;里…

14 代碼分割之lazy:Suspense與路由懶加載

lazy內置方法 Suspense內置組件 lazy是React提供的懶&#xff08;動態&#xff09;加載組件的方法&#xff0c;React.lazy() 能減少打包體積、延遲加載首屏不需要渲染的組件 依賴內置組件Suspense&#xff1a;給lazy加上loading指示器組件的一個容器組件 Suspense目前只和la…

三年工作的總結

其實開通博客已經有四年之久了,但遺憾的是從來沒有認真寫過一篇博客,只是在平時會瀏覽一些大牛寫過的博客。 其實我覺得做技術的定期總結自己的經驗還是很重要的。 不知不覺參加工作已經三年了,三年時間真的過得很快,想當初帶著一腔熱血,一個背包走天下,來到上海,從零開始&…

css --- 兄弟選擇器

語法: /* 查找后邊的一個兄弟元素 */ 兄弟元素 兄弟元素/* 查找后邊的所有兄弟元素 */ 兄弟元素 ~ 兄弟元素<head><style>#maindiv {color: red;}#main~div {background-color: #e0e0e0;}</style> </head> <body><div id"main"&g…

面向對象特征:封裝、多態 以及 @propetry裝飾器

&#xff08;繼承補充&#xff09;組合objfun()#對象obj.attrfoo()#對象的屬性等于另一個對象什么是組合&#xff1a; A類的對象具備某一個屬性&#xff0c;該屬性的值是B類的對象基于這種方式就把A類與B類組合到一起對象既能使用A類中的數據與功能&#xff0c;也能使用B類中的…

15 錯誤邊界與使用技巧

錯誤邊界 React16增加防止某個組件的UI渲染錯誤導致整個應用崩潰子組件發生JS錯誤&#xff0c;有備用的渲染UI錯誤邊界是組件&#xff0c;只能用class組件來寫 錯誤邊界組件捕獲錯誤的時機 渲染時生命周期函數中組件樹的構造函數中 getDerivedStateFromError 生命周期函數…

深入探究Spark -- Cluster Manger部署(最常用為YARN實現Task Scheduler)

部署方式有&#xff1a;Standalone&#xff08;Spark的Deploy模塊&#xff09;、Mesos、YARN、EC2、LocalSparkContext創建時&#xff0c;通過傳入的Master URL不同&#xff0c;創建不同的SchedulerBackend和TaskScheduler&#xff0c;在spark.SparkContext#createTaskSchuster…

es6 --- Promise.all等待多個異步任務執行

項目中遇到一個問題,要用多個http請求,獲取數據,然后將獲取的數據統一處理… 第一反應想到用promise.all來做… 下面進入主體 // 首先使用promise封裝http請求. function getListByDetecttype (params) {return new Promise((resolve, reject) > {let param params ? par…

16 代碼分割之錯誤邊界與Suspense和命名導出

代碼分割之錯誤邊界與Suspense const Main React.lazy(() > import(./main)) class ErrorBoundary extends React.Component {state {hasError: false,}static getDerivedStateFromError(err) {console.log(getDerivedStateFromError err, err)return {hasError: true}}c…

Python 原生爬蟲

Python3 實現游戲主播人氣排行榜 from urllib import request import re# 爬取某個游戲主播的人氣&#xff08;每個游戲主播的觀看人數&#xff09;排行榜 爬蟲前奏&#xff1a;明確爬蟲目的找到數據對應的網頁分析網頁的結構找到數據所在的標簽位置模擬HTTP請求&#xff0c;向…

Mac 下查看網絡端口占用情況

1、Mac 下查看網絡端口占用情況 有的時候關閉了服務器&#xff0c;但是端口還是占用&#xff0c;解決的方法是 kill 掉占用該端口的進程。 # 查看 8009 端口的占用情況 $ lsof -i:8009 可以看到&#xff0c;該端口被 id 為 4215 的進程所占用&#xff0c;這個時候直接在命令…

javascript --- 變量提升的理解

看下面一段代碼: (function () {var x foo();var foo function foo () {return "foobar";};return x; })();(不許打出來)猜猜返回結果是什么… 答案是 // foo is not a function下面來解釋為什么會這樣,首先得明白: 1.如果變量聲明了但未賦值,則會顯示undefined…

17 初探Context的使用場景

context 容器&#xff08;即上下文&#xff09; → 裝數據 → 可以傳遞到程序的多個地方程序在執行時可訪問的容器 import styles from ...則css要寫module.css&#xff0c;否則無效果&#xff1b; import from ...則css無須寫module. &#xff0c;否則無效果 使用 context.j…

分布式監控系統開發【day37】:需求討論(一)

本節內容 為什么要做監控&#xff1f; 常用監控系統設計討論監控需求討論如何實現監控服務器的水平擴展&#xff1f;監控系統架構設計一、為什么要做監控&#xff1f; 熟悉IT監控系統的設計原理開發一個簡版的類Zabbix監控系統掌握自動化開發項目的程序設計思路及架構解藕原則…

iOS:練習題中如何用技術去實現一個連線題

一、介紹 本人做的app涉及的是教育行業&#xff0c;所以關于練習題的開發肯定是家常便飯。例如&#xff0c;選擇題、填空題、連線題、判斷題等&#xff0c;每一種題型都需要技術去實現&#xff0c;沒啥多大難度&#xff0c;這里呢&#xff0c;就給出實現連線題的核心代碼吧。過…

18 Context與組合的應用場景與使用問題

contextType 指定context類型為創建的上下文&#xff0c;此時不需要用Consumer組件包裹&#xff0c;使用this.context即可訪問會向上找最近的上下文并取值最適合的場景&#xff1a;雜亂無章的組件都需要同一些數據&#xff1b;若單純為了不層層傳遞屬性&#xff0c;使用contex…

http --- 共享加密(對稱加密)的幾個概念

使用互聯網進行數據傳輸時,可能會產生以下四個問題: 1. 竊聽: A向B發送的消息,有可能在傳輸過程中被X竊聽到 2. 假冒: A收到來自B的消息有可能是X冒充的 3. 篡改: A確實收到來自B的消息,但是該消息有可能被X篡改了 4. 事后否認:B確實收到了來自A的消息,但是A是惡意用戶,當A像B…

213. House Robber II 首尾相同的偷竊問題

&#xff3b;抄題&#xff3d;&#xff1a; You are a professional robber planning to rob houses along a street. Each house has a certain amount of money stashed. All houses at this place are arranged in a circle. That means the first house is the neighbor of…