摘要:修復了這一點,引入了的概念,中文譯為錯誤邊界,當某個組件發(fā)生錯誤時,我們可以通過捕獲到錯誤并對錯誤做優(yōu)雅處理。擴展采用了最新的技術(shù),你可以在點擊這里來閱讀官方文檔暫時就這么多,后續(xù)發(fā)現(xiàn)更多我再進行更新,希望大家喜歡
React v16.0
如果返回數(shù)組必須給每一個數(shù)組元素添加一個唯一標識key,但是從v16.2開始reat
// 第一種返回數(shù)組 render() { // 這里不同于v15.x必須要一個標簽來包裹 return [ // key是必須的,一般不要把數(shù)組的index索引作為key,這樣可能會導致頁面不會按照你想象的效果進行渲染
之前react在渲染過程中或者是生命周期內(nèi)出現(xiàn)了致命的錯誤,react會從根組件上把所有的組件都卸載下來,以防止展現(xiàn)錯誤的數(shù)據(jù),但這不是最好的用戶體驗。React 16修復了這一點,引入了Error Boundary的概念,中文譯為“錯誤邊界”,當某個組件發(fā)生錯誤時,我們可以通過Error Boundary捕獲到錯誤并對錯誤做優(yōu)雅處理。(注:它并不能捕獲runtime所有的錯誤,比如組件回調(diào)事件里的錯誤,可以把它想象成傳統(tǒng)的try-catch語句)
class ErrorBoundary extends React.Component { constructor(props) { super(props); this.state = { hasError: false }; } // 新增了componentDidCatch這個生命周期函數(shù),它可以捕獲自身及子樹上的錯誤并對錯誤做優(yōu)雅處理,包括上報錯誤日志、展示出錯提示,而不是卸載整個組件樹。 componentDidCatch(error, info) { // 錯誤代理組件的展示與否 this.setState({ hasError: true }); // 在這里我們可以對錯誤進行記錄 logErrorToMyService(error, info); } render() { if (this.state.hasError) { // 在這里我們可以書寫自己想要展示的ui組件 returnSomething went wrong.
; } return this.props.children; } }
上面的組件是當頁面中有錯誤時我們想要展示的效果,具體用法如下:
render(){ return () }// 外層組件我們定義的錯誤組件 // 內(nèi)層組件是我們將要監(jiān)視的自定義組件
這個組件能夠不僅僅能夠監(jiān)聽到本組件的錯誤,連同它下面的子組件的錯誤也可以監(jiān)聽到
setState傳入null時不會再觸發(fā)更新
之前的setState不管傳入什么只要調(diào)用了這么方法就會渲染
selectCity(e){ const newValue = e.target.value; this.setState((state)=>{ if(state.city===newValue){ return null; } return {city:newValue} }) )v16.0支持自定義的dom屬性
之前的版本對于自定義屬性react會在屬性前加上data-**來進行處理,現(xiàn)在對于部分屬性去除了這種寫法,擁抱了原生dom,這樣可以減少react的代碼,提升了性能
從數(shù)據(jù)來說,React v16比v15.6版本縮小了32%更好的服務器端渲染:React 16的SSR被完全重寫,新的實現(xiàn)非??欤咏?倍性能于React 15,現(xiàn)在提供一種流模式streaming,可以更快地把渲染的字節(jié)發(fā)送到客戶端。
擴展react v16采用了最新的技術(shù)“Fiber.”,你可以在點擊這里來閱讀官方文檔
暫時就這么多,后續(xù)發(fā)現(xiàn)更多我再進行更新,希望大家喜歡
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/92577.html
摘要:又雙叒更新啦這次是,其實在前段時間就知道最近要發(fā)布了。協(xié)議更新了。。。這樣做是為了阻止損壞數(shù)據(jù)的顯示。協(xié)議的協(xié)議已經(jīng)是協(xié)議了,當然,也把已經(jīng)發(fā)布的頁改成協(xié)議了。 React 又雙叒更新啦~ 這次是React v16.0,其實在前段時間就知道最近要發(fā)布了。協(xié)議更新了。。。來看看其他的變化吧。自己看著玩的。。期待官方中文文檔的更新。。 原文地址:React v16.0 我們很高興地宣布發(fā)...
摘要:然而之前的相當于從最頂層的組件開始,自頂向下遞歸調(diào)用,不會被中斷,這樣就會持續(xù)占用瀏覽器主線程。眾所周知,是單線程運行,長時間占用主線程會阻塞其他類似于樣式計算布局繪制等運算,從而出現(xiàn)掉幀的情況。 前言 首先歡迎大家關(guān)注我的Github博客,也算是對我的一點鼓勵,畢竟寫東西沒法獲得變現(xiàn),能堅持下去也是靠的是自己的熱情和大家的鼓勵,希望大家多多關(guān)注呀!從今年年初離開React開發(fā)崗,...
摘要:大約一年前,團隊發(fā)布了。時至今日,已更新到。這其中有不少激動人心的特性如架構(gòu)的引入新的周期函數(shù)全新等都值得開發(fā)者跟進學習。本文就以更新日志為引,選取幾個重要且用于工作的更新,和大家一起學習。所有示例代碼在配合文章一起食用更佳 大約一年前,React 團隊發(fā)布了 React 16.0。時至今日,已更新到 16.5 。這其中有不少激動人心的特性(如 Fiber 架構(gòu)的引入、新的周期函數(shù)、全...
摘要:的返回值將作為的參數(shù),如果返回,則不更新,不能返回或以外的值,否則會警告。在更新之前調(diào)用,此時已更新返回值作為的第個參數(shù)一般用于獲取之前的數(shù)據(jù)語法是從的返回值,默認是的使用場景一般是獲取組建更新之前的滾動條位置。 React16 后的各功能點是多個版本陸陸續(xù)續(xù)迭代增加的,本篇文章的講解是建立在 16.6.0 版本上本篇文章主旨在介紹 React16 之后版本中新增或修改的地方,所以對于...
閱讀 4325·2021-10-13 09:39
閱讀 494·2021-09-06 15:02
閱讀 3236·2019-08-30 15:53
閱讀 1051·2019-08-30 13:04
閱讀 2057·2019-08-30 11:27
閱讀 2020·2019-08-26 13:51
閱讀 2105·2019-08-26 11:33
閱讀 2911·2019-08-26 10:36