網(wǎng)站首頁 編程語言 正文
Facebook團(tuán)隊(duì)對(duì)社區(qū)上的MVC框架都不太滿意的情況下,開發(fā)了一套開源的前端框架react,于2013年發(fā)布第一個(gè)版本。
react最開始倡導(dǎo)函數(shù)式編程,使用function以及內(nèi)部方法React.creactClass創(chuàng)建組件,之后在ES6推出之后,使用類組件Class構(gòu)建包含生命周期的組件。
react 16.8版本更新
react16.8版本更新標(biāo)志性的信息,是引入了hooks以及相關(guān)的一些api。
useState: // 函數(shù)式組件初始化state和更改state: const Counter = () =>{ const [num,setNum] = userState(0); return(); };{count}
useEffect
userEffect副作用函數(shù)的組件,不僅取代了組件初始化,組件掛載成功,組件狀態(tài)更新這三個(gè)階段的生命周期函數(shù)
同時(shí)還能在這個(gè)階段處理一些內(nèi)存隊(duì)列:包括定時(shí)器等,解決了在16.8版本之前,在組件移除之后,異步隊(duì)列沒有被移除,占據(jù)內(nèi)存導(dǎo)致頁面卡頓等問題
useEffect(() => { compoment.subscribe(id); return () => { compoment.unsubscribe(theId) //取消訂閱 } });
react16.8版本更新解決了什么問題
組件復(fù)用更便捷
在更新的版本之前,復(fù)用組件,更多的是使用高階組件,以及封裝的組件,通過傳參和父子組件通信的形式去復(fù)用,
更新之后,可以通過函數(shù)式組件返回狀態(tài)的形式,去接受組件向外暴露的組件內(nèi)容。
實(shí)例
//舊版本 function children() { return function (WrappedComponent) { return class HighComponent extends React.Component { state = { childProps: xxx }; render() { const { childProps } = this.state; return; } }; }; }
class App extends Component{ render(){ /** * 調(diào)用高階組件 */ const { childProps} = this.props; return () } }
// 新版本 function children() { const [childProps, setChildProps] = useState(xxx); return childProps; } function App { const { childProps} = useTable(); return (
- 在我們上面提到的,清除定時(shí)器,以及解決在生命周期變化過程中,消除占用內(nèi)存的隊(duì)列等
- 函數(shù)式組件出現(xiàn)了狀態(tài)管理,在以往的react函數(shù)式編程過程中,react只能被動(dòng)去接收一個(gè)從父組件傳遞下來的一個(gè)props狀態(tài),在hooks更新之后,可以使用hooks更新的方法,提高組件的功能性以及擴(kuò)展性,在函數(shù)式組件當(dāng)中擁有了像class組件一樣可控生命周期
- useEffect取代了一部分生命周期函數(shù),從代碼量的角度來說,簡化了代碼,解決了在class組件在編寫過程中,需要不斷使用bind或者箭頭函數(shù)去綁定當(dāng)前的this,更專注于當(dāng)前狀態(tài)的管理
hooks和react diff算法
- react diff這里不做深入講解,簡單來說diff算法是react以及vue2.0版本當(dāng)中:
內(nèi)部有一套虛擬dom的算法,在組件渲染過程中,對(duì)每個(gè)dom渲染一個(gè)key值,
在state狀態(tài)更新過程時(shí),對(duì)應(yīng)渲染的虛擬dom會(huì)去對(duì)比真實(shí)渲染在頁面上的dom元素,如果某個(gè)節(jié)點(diǎn)對(duì)比時(shí)發(fā)現(xiàn)有更改,對(duì)應(yīng)更改當(dāng)前虛擬dom節(jié)點(diǎn)的數(shù)據(jù)狀態(tài),再渲染真實(shí)的dom到頁面當(dāng)中。
兩者的聯(lián)系:
hooks在更新之后,減少了對(duì)生命周期函數(shù)的執(zhí)行,同時(shí)更新狀態(tài)更為迅速,這樣在虛擬dom執(zhí)行過程中,提高diff執(zhí)行速度
hooks使得函數(shù)式組件有了自己內(nèi)部的狀態(tài),在函數(shù)式組件執(zhí)行過程中,不需要等待裝載到父組件當(dāng)中,自己可以更新狀態(tài),所以減少了部分dom的深度,在頁面渲染過程中,也算是變相提高了頁面渲染速度。
總結(jié)
hooks在出現(xiàn)之后,對(duì)react前端開發(fā)來說,標(biāo)志性的特點(diǎn)應(yīng)該是解決了類似定時(shí)器隊(duì)列占據(jù)內(nèi)存的問題,簡化了react生命周期和組件代碼,追溯數(shù)據(jù)流向和狀態(tài)修改更為清晰。
在16.8版本之后的小版本更是出現(xiàn)了自定義hooks,還有usememo等api,
包含vue3.0新的api,這些版本的更新都在幫助前端開發(fā)者不用再花更多的時(shí)間去研究生命周期執(zhí)行和運(yùn)行的過程,去專注頁面上狀態(tài)的改變,快速和穩(wěn)健開發(fā)前端業(yè)務(wù)。
原文鏈接:https://www.cnblogs.com/akari16/p/16004571.html
相關(guān)推薦
- 2023-07-25 BigDecimal詳解
- 2022-12-09 Android入門之ProgressBar的使用教程_Android
- 2022-07-16 不同存圖方式下的DFS和BFS實(shí)現(xiàn)
- 2023-01-13 Pytorch實(shí)現(xiàn)Fashion-mnist分類任務(wù)全過程_python
- 2022-10-15 Go?Excelize?API源碼閱讀GetPageLayout及SetPageMargins_Go
- 2022-08-15 spring5:創(chuàng)建spring項(xiàng)目并引入jar包
- 2023-03-26 使用docker安裝hadoop的實(shí)現(xiàn)過程_docker
- 2022-08-30 C語言深入詳解四大內(nèi)存函數(shù)的使用_C 語言
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支