實例講解React 組件
本章節(jié)我們將討論如何使用組件使得我們的應用更容易來管理。
接下來我們封裝一個輸出 "Hello World!" 的組件,組件名為 HelloMessage:
function HelloMessage(props) {
return <h1>Hello World!</h1>;
}
const element = <HelloMessage />;
ReactDOM.render(
element,
document.getElementById('example')
);
實例解析:
1、我們可以使用函數定義了一個組件:
function HelloMessage(props) {
return <h1>Hello World!</h1>;
}
你也可以使用 ES6 class 來定義一個組件:
class Welcome extends React.Component {
render() {
return <h1>Hello World!</h1>;
}
}
2、const element = <HelloMessage /> 為用戶自定義的組件。
注意,原生 HTML 元素名以小寫字母開頭,而自定義的 React 類名以大寫字母開頭,比如 HelloMessage 不能寫成 helloMessage。除此之外還需要注意組件類只能包含一個頂層標簽,否則也會報錯。
如果我們需要向組件傳遞參數,可以使用 this.props 對象,實例如下:
function HelloMessage(props) {
return <h1>Hello {props.name}!</h1>;
}
const element = <HelloMessage name="jb51"/>;
ReactDOM.render(
element,
document.getElementById('example')
);
以上實例中 name 屬性通過 props.name 來獲取。
注意,在添加屬性時, class 屬性需要寫成 className ,for 屬性需要寫成 htmlFor ,這是因為 class 和 for 是 JavaScript 的保留字。
復合組件
我們可以通過創(chuàng)建多個組件來合成一個組件,即把組件的不同功能點進行分離。
以下實例我們實現(xiàn)了輸出網站名字和網址的組件:
function Name(props) {
return <h1>網站名稱:{props.name}</h1>;
}
function Url(props) {
return <h1>網站地址:{props.url}</h1>;
}
function Nickname(props) {
return <h1>網站小名:{props.nickname}</h1>;
}
function App() {
return (
<div>
<Name name="腳本之家" />
<Url url="http://www.dhdzp.com/" />
<Nickname nickname="jb51" />
</div>
);
}
ReactDOM.render(
<App />,
document.getElementById('example')
);
輸出結果:

以上就是實例講解React 組件的詳細內容,更多關于React 組件的資料請關注腳本之家其它相關文章!
- React嵌套組件的構建順序
- 編寫簡潔React組件的小技巧
- 使用hooks寫React組件需要注意的5個地方
- react實現(xiàn)Radio組件的示例代碼
- 詳解對于React結合Antd的Form組件實現(xiàn)登錄功能
- 基于react hooks,zarm組件庫配置開發(fā)h5表單頁面的實例代碼
- React antd tabs切換造成子組件重復刷新
- 在react-antd中彈出層form內容傳遞給父組件的操作
- 在react項目中使用antd的form組件,動態(tài)設置input框的值
- react實現(xiàn)復選框全選和反選組件效果
- 利用React高階組件實現(xiàn)一個面包屑導航的示例
- 實例講解React 組件生命周期
- 詳解React 父組件和子組件的數據傳輸
相關文章
使用 Rails API 構建一個 React 應用程序的詳細步驟
這篇文章主要介紹了使用 Rails API 構建一個 React 應用程序的詳細步驟,主要包括后端:Rails API部分,前端:React部分及React組件的相關操作,具有內容詳情跟隨小編一起看看吧2021-08-08
React利用props的children實現(xiàn)插槽功能
React中并沒有vue中的?slot?插槽概念?不過?可以通過props.children?實現(xiàn)類似功能,本文為大家整理了實現(xiàn)的具體方,需要的可以參考一下2023-07-07
解決antd的Table組件使用rowSelection屬性實現(xiàn)多選時遇到的bug
這篇文章主要介紹了解決antd的Table組件使用rowSelection屬性實現(xiàn)多選時遇到的bug問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08

