React組件與事件的創(chuàng)建使用教程
創(chuàng)建組件
函數(shù)組件
函數(shù)組件:使用JS的函數(shù)或者箭頭函數(shù)創(chuàng)建的組件
- 使用 JS 的函數(shù)(或箭頭函數(shù))創(chuàng)建的組件,叫做函數(shù)組件
- 約定1:函數(shù)名稱必須以大寫字母開頭,React 據(jù)此區(qū)分組件和普通的 HTML
- 約定2:函數(shù)組件必須有返回值,表示該組件的 UI 結(jié)構(gòu)
// 1. 導(dǎo)包
import React from 'react'
import ReactDom from 'react-dom/client'
// 2. 創(chuàng)建 函數(shù)式組件
// 普通函數(shù)或者箭頭函數(shù)創(chuàng)建組件,首字母大寫
// 組件必須要有返回值
function Music() {
return (
<div>
<h1>haha</h1>
</div>
)
}
const VNode = (
<div>
<Music></Music>
</div>
)
// 3. 掛載
ReactDom.createRoot(document.querySelector('#root')).render(VNode)
類組件
類組件:使用 ES6 的 class 創(chuàng)建的組件,叫做類(class)組件
- 約定1:類名稱也必須以大寫字母開頭
- 約定2:類組件應(yīng)該繼承
React.Component父類,從而使用父類中提供的方法或?qū)傩?/li> - 約定3:類組件必須提供
render方法 - 約定4:render 方法必須有返回值,表示該組件的 UI 結(jié)構(gòu)
// 1. 導(dǎo)包
import React from 'react'
import ReactDom from 'react-dom/client'
// 2.
class Hello extends React.Component {
render() {
return <h1>哈哈</h1>
}
}
const VNode = (
<>
<Hello></Hello>
</>
)
// 3. 掛載
ReactDom.createRoot(document.querySelector('#root')).render(VNode)
組件提取到單獨(dú)的文件中
在components文件夾下,創(chuàng)建函數(shù)組件hello.js,類組件home.js,
hello.js
const Hello = () => <h1>我是hello組件</h1> export default Hello
home.js
import React from 'react'
class Home extends React.Component {
render() {
return <h2>home</h2>
}
}
export default Home
在index.js中導(dǎo)入
// 1. 導(dǎo)包
import React from 'react'
import ReactDom from 'react-dom/client'
// 導(dǎo)入組件
import Hello from './components/hello'
import Home from './components/home'
// 2. 創(chuàng)建虛擬DOM
const App = (
<>
<Hello></Hello>
<Home></Home>
</>
)
// 3. 掛載
ReactDom.createRoot(document.querySelector('#root')).render(App)
有狀態(tài)組件與無狀態(tài)組件
狀態(tài)即數(shù)據(jù)
- 函數(shù)組件又叫做無狀態(tài)組件 函數(shù)組件是不能自己提供數(shù)據(jù) 【前提:基于hooks之前說的 16.8之前】
- 類組件又叫做有狀態(tài)組件類組件可以自己提供數(shù)據(jù),數(shù)據(jù)如果發(fā)生了改變,內(nèi)容會(huì)自動(dòng)的更新
- 組件的私有數(shù)據(jù)也稱為狀態(tài) ,當(dāng)組件的狀態(tài)發(fā)生了改變,頁面結(jié)構(gòu)也就發(fā)生了改變?!緮?shù)據(jù)驅(qū)動(dòng)視圖】
- 函數(shù)組件是沒有狀態(tài)的,只負(fù)責(zé)頁面的展示(靜態(tài),不會(huì)發(fā)生變化)性能比較高
- 類組件有自己的狀態(tài),負(fù)責(zé)更新UI,只要類組件的數(shù)據(jù)發(fā)生了改變,UI就會(huì)發(fā)生更新(動(dòng)態(tài))。
- 在復(fù)雜的項(xiàng)目中,一般都是由函數(shù)組件和類組件共同配合來完成的。
// 1. 導(dǎo)包
import React from "react"
import ReactDom from 'react-dom/client'
// 函數(shù)組件 沒有狀態(tài) 僅僅做一些數(shù)據(jù)展示的工作,可以使用函數(shù)組件
// function App() {
// return (
// <div>我是組件</div>
// )
// }
// 類組件 有狀態(tài) 如果有狀態(tài),狀態(tài)需要切換,更新視圖 用類組件
class App extends React.Component {
render() {
return (
<h1>我是類組件</h1>
)
}
}
const VNode = (
<div>
<App></App>
</div>
)
ReactDom.createRoot(document.querySelector('#root')).render(VNode)
類組件的狀態(tài)
- 狀態(tài)
state即數(shù)據(jù),是組件內(nèi)部的私有數(shù)據(jù),只有在組件內(nèi)部可以使用 - state的值是一個(gè)對(duì)象,表示一個(gè)組件中可以有多個(gè)數(shù)據(jù)
- 通過
this.state.xxx來獲取狀態(tài)
// 1. 導(dǎo)包
import React from "react"
import ReactDom from 'react-dom/client'
// 類組件 有狀態(tài) 如果有狀態(tài),狀態(tài)需要切換,更新視圖 用類組件
class App extends React.Component {
// state節(jié)點(diǎn)中提供狀態(tài)
// 通過 this.state.xxx 來獲取狀態(tài)
state = {
name: 'Tt',
age: 17
}
render() {
return (
<h1>{this.state.name} ----- {this.state.age}</h1>
)
}
}
const VNode = (
<div>
<App></App>
</div>
)
ReactDom.createRoot(document.querySelector('#root')).render(VNode)
事件處理
注冊(cè)事件
語法:on+事件名={事件處理程序} 比如onClick={this.handleClick}
// 1. 導(dǎo)包
import React from "react"
import ReactDom from 'react-dom/client'
// 類組件 有狀態(tài) 如果有狀態(tài),狀態(tài)需要切換,更新視圖 用類組件
class App extends React.Component {
// state節(jié)點(diǎn)中提供狀態(tài) 通過 this.state.xxx 來獲取狀態(tài)
state = {
name: 'Tt',
age: 17
}
// 提供一些方法
handleClick() {
console.log('點(diǎn)擊');
}
render() {
return (
<div>
<button onClick={this.handleClick}>按鈕</button>
</div>
)
}
}
const VNode = (
<div>
<App></App>
</div>
)
ReactDom.createRoot(document.querySelector('#root')).render(VNode)
到此這篇關(guān)于React組件與事件的創(chuàng)建使用教程的文章就介紹到這了,更多相關(guān)React組件與事件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ReactNative中使用Redux架構(gòu)總結(jié)
本篇文章主要介紹了ReactNative中使用Redux架構(gòu)總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-12-12
使用React和Redux Toolkit實(shí)現(xiàn)用戶登錄功能
在React中,用戶登錄功能是一個(gè)常見的需求,為了實(shí)現(xiàn)該功能,需要對(duì)用戶輸入的用戶名和密碼進(jìn)行驗(yàn)證,并將驗(yàn)證結(jié)果保存到應(yīng)用程序狀態(tài)中,在React中,可以使用Redux Toolkit來管理應(yīng)用程序狀態(tài),從而實(shí)現(xiàn)用戶登錄功能,需要詳細(xì)了解可以參考下文2023-05-05
React?實(shí)現(xiàn)具備吸頂和吸底功能組件實(shí)例
這篇文章主要為大家介紹了React?實(shí)現(xiàn)具備吸頂和吸底功能組件實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
React入門教程之Hello World以及環(huán)境搭建詳解
Facebook 為了開發(fā)一套更好更適合自己的JavaScript MVC 框架,所以產(chǎn)生了react。后來反響很好,所以于2013年5月開源。下面這篇文章主要給大家介紹了關(guān)于React入門教程之Hello World以及環(huán)境搭建的相關(guān)資料,需要的朋友可以參考借鑒。2017-07-07
如何利用React實(shí)現(xiàn)圖片識(shí)別App
圖片識(shí)別這個(gè)功能在很多app中都有,下面這篇文章主要給大家介紹了關(guān)于如何利用React實(shí)現(xiàn)圖片識(shí)別App的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-01-01
React項(xiàng)目經(jīng)驗(yàn)總結(jié)及遇到的坑
這篇文章主要介紹了React項(xiàng)目經(jīng)驗(yàn)總結(jié),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07
react?component?function組件使用詳解
這篇文章主要為大家介紹了react?component?function組件的使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11

