React入門--第三天--函式元件
函式元件
- 建立方式
- 沒有state怎麼辦
- 沒有生命週期怎麼辦
- useState原理
建立元件
const Hello = (props) => {
return <div>{props.message}</div>
}
const Hello = props => <div>{props.message}</div>
function Hello(props) {
return <div>{props.message}</div>
}
函式元件代替class元件
面臨兩個問題
- 函式元件沒有state
- 函式元件沒有生命週期
解決
沒有state
- Hooks API中叫做useState可以解決問題
沒有生命週期
- Hooks API叫做useEffect可以解決問題
函式元件實現一個+1功能
const App = props => {
const [n,setN] = useState(0)
const onClick = () => {
setN(n+1)
}
return (
<div>
{n}
<button onClick={onClick}>+1</button>
</div>
)
}
export default App;
用函式元件就簡單很多,沒有放出class元件實現的程式碼,而且函式元件消除了this
函式元件模擬生命週期
useEffect
模擬componentDidMount
useEffect(()=>{console.log('第一次渲染')},[])
模擬componentDidUpdate
useEffect(()=>{console.log('任意屬性變更')})
useEffect(()=>{console.lod('n變了')},[n])
模擬componentWillUnmount
useEffect(()=>{console.log('第一次渲染') return ()=>{console('元件要死了')} })
後面的引數
[]
就是第一次呼叫[n]
就是n更新的時候執行,第一次也會執行[n,m]
就是n或者m變了就會執行,第一次也會執行- 如果是任何一個state(全部變數)變化都執行,那麼
[引數]
整個這個東西就可以不寫
函式元件的組合起來特別簡單
const x = () => {
return <div>x</div>
}
const y = () => {
return <div>y</div>
}
const z = () => {
return <>
<x></x>
<y></y>
</>
}
函式元件寫起來程式碼少,但是難一點
有一個問題
模擬componentDidUpdate
useEffect(()=>{console.lod('n變了')},[n])
在初始化的時候也會執行,那怎麼才能在只有變化的時候才執行這個程式碼呢,就是第一次不執行
自定義hook
import React, {useState, useEffect } from "react";
const App = props => {
const [n, setN] = useState(0);
const onClick = () => {
setN(n+1);
};
const [nUpdateCount, setNUpdateCount] = useState(0)
useEffect(() => {
setNUpdateCount(x=>x+1)//這裡x是接受的引數,就是nUpdateCount
}, [n])//n變了就把計數器加一
useEffect(()=>{
if(nUpdateCount > 1) {
console.log('n變了');
}
}, [nUpdateCount])//n變了,計數器就會變化,也就是相當於n變了
return (
<div>
{n}
<button onClick={onClick}>+1</button>
</div>
)
}
export default App;
這樣就實現了這個功能
但是程式碼太雜了,我們可以封裝一個函式
const useX = (n) => {
const [nUpdateCount, setNUpdateCount] = useState(0)
useEffect(() => {
setNUpdateCount(x=>x+1)//這裡x是接受的引數,就是nUpdateCount
}, [n]);
return {
nUpdateCount: nUpdateCount
}
};
const nUpdateCount = useX(n).nUpdateCount
useEffect(()=>{
if(nUpdateCount > 1) {
console.log('n變了');
}
}, [nUpdateCount])
然後改成了這這樣
再改
const useUpdate = (fn, dep) => {
const [Count, setCount] = useState(0)
useEffect(() => {
setCount(x=>x+1)
}, [dep]);
useEffect(()=>{
if(Count > 1) {
fn();
}
}, [Count, fn])
};
useUpdate(()=>{
console.log('n變了')
}, n)
就封裝了一個函式useUpdate
,和useEffect
非常像
也可以直接拆分成一個元件,元件化
函式元件牛逼!!!
相關文章
- React函式式元件和類元件[Dan]React函式元件
- ReactNative入門教程-元件生命週期函式React元件函式
- React函式式元件的效能優化React函式元件優化
- react hooks 如何自定義元件(react函式元件的封裝)ReactHook元件函式封裝
- React 是如何分辨函式式元件和類元件的?React函式元件
- [譯]React函式元件和類元件的差異React函式元件
- Python入門-函式Python函式
- 前端入門——函式前端函式
- 11函式入門函式
- 生成函式入門函式
- 【譯】 React官方:函式元件與類元件的差異 ?React函式元件
- react之bind函式到元件通識篇React函式元件
- 尤拉函式入門函式
- PHP入門之函式PHP函式
- 集合與函式入門函式
- python入門:range函式Python函式
- [譯] 函式式 JavaScript 快速入門函式JavaScript
- python-函式入門(一)Python函式
- day07-函式入門函式
- 3.JavaScript函式入門JavaScript函式
- JavaScript入門-函式function(二)JavaScript函式Function
- React高階元件入門與常用用法React元件
- python入門必會的助手函式:dir()函式Python函式
- 函式式元件函式元件
- 2020/09/24 react中函式元件父元件動態向子元件傳值React函式元件
- react設計--他怎麼知道是類元件還是函式元件React元件函式
- 分散式日誌元件GrayLog入門分散式元件
- 停止在 React 元件回撥中使用箭頭函式!React元件函式
- 數論函式從入門到進門函式
- C++入門記-建構函式和解構函式C++函式
- 函式式DDD架構入門 - SCOTT WLASCHIN函式架構
- JavaScript 高階函式快速入門JavaScript函式
- Python入門之函式呼叫(二)Python函式
- [MySQL光速入門]024 聊聊函式MySql函式
- 【譯】函式式的React函式React
- [譯]使用React.memo()來優化函式元件的效能React優化函式元件
- Go 入門 – 包,函式和變數Go函式變數
- TypeScript基礎入門-函式-簡介TypeScript函式