成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

最官方的react16.0更新功能

xingpingz / 853人閱讀

摘要:修復了這一點,引入了的概念,中文譯為錯誤邊界,當某個組件發(fā)生錯誤時,我們可以通過捕獲到錯誤并對錯誤做優(yōu)雅處理。擴展采用了最新的技術(shù),你可以在點擊這里來閱讀官方文檔暫時就這么多,后續(xù)發(fā)現(xiàn)更多我再進行更新,希望大家喜歡

React v16.0
September 26, 2017 by Andrew Clark
新版本的render可以返回數(shù)組、字符串、react組件、數(shù)字、boolean值

如果返回數(shù)組必須給每一個數(shù)組元素添加一個唯一標識key,但是從v16.2開始reat

// 第一種返回數(shù)組
render() {
  // 這里不同于v15.x必須要一個標簽來包裹
  return [
    // key是必須的,一般不要把數(shù)組的index索引作為key,這樣可能會導致頁面不會按照你想象的效果進行渲染
    
  • First item
  • ,
  • Second item
  • ,
  • Third item
  • , ]; } // 第二種返回字符串 render() { return "Look ma, no spans!"; }

    更好的錯誤處理方式

    之前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組件
          return 

    Something 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

    相關(guān)文章

    • React 16 發(fā)布啦。。渣渣看了一下更新文檔~

      摘要:又雙叒更新啦這次是,其實在前段時間就知道最近要發(fā)布了。協(xié)議更新了。。。這樣做是為了阻止損壞數(shù)據(jù)的顯示。協(xié)議的協(xié)議已經(jīng)是協(xié)議了,當然,也把已經(jīng)發(fā)布的頁改成協(xié)議了。 React 又雙叒更新啦~ 這次是React v16.0,其實在前段時間就知道最近要發(fā)布了。協(xié)議更新了。。。來看看其他的變化吧。自己看著玩的。。期待官方中文文檔的更新。。 原文地址:React v16.0 我們很高興地宣布發(fā)...

      xi4oh4o 評論0 收藏0
    • 重拾React: React 16.0

      摘要:然而之前的相當于從最頂層的組件開始,自頂向下遞歸調(diào)用,不會被中斷,這樣就會持續(xù)占用瀏覽器主線程。眾所周知,是單線程運行,長時間占用主線程會阻塞其他類似于樣式計算布局繪制等運算,從而出現(xiàn)掉幀的情況。 前言   首先歡迎大家關(guān)注我的Github博客,也算是對我的一點鼓勵,畢竟寫東西沒法獲得變現(xiàn),能堅持下去也是靠的是自己的熱情和大家的鼓勵,希望大家多多關(guān)注呀!從今年年初離開React開發(fā)崗,...

      henry14 評論0 收藏0
    • 盤點 React 16.0 ~ 16.5 主要更新及其應用

      摘要:大約一年前,團隊發(fā)布了。時至今日,已更新到。這其中有不少激動人心的特性如架構(gòu)的引入新的周期函數(shù)全新等都值得開發(fā)者跟進學習。本文就以更新日志為引,選取幾個重要且用于工作的更新,和大家一起學習。所有示例代碼在配合文章一起食用更佳 大約一年前,React 團隊發(fā)布了 React 16.0。時至今日,已更新到 16.5 。這其中有不少激動人心的特性(如 Fiber 架構(gòu)的引入、新的周期函數(shù)、全...

      idealcn 評論0 收藏0
    • React16時代,該用什么姿勢寫 React ?

      摘要:的返回值將作為的參數(shù),如果返回,則不更新,不能返回或以外的值,否則會警告。在更新之前調(diào)用,此時已更新返回值作為的第個參數(shù)一般用于獲取之前的數(shù)據(jù)語法是從的返回值,默認是的使用場景一般是獲取組建更新之前的滾動條位置。 React16 后的各功能點是多個版本陸陸續(xù)續(xù)迭代增加的,本篇文章的講解是建立在 16.6.0 版本上本篇文章主旨在介紹 React16 之后版本中新增或修改的地方,所以對于...

      Reducto 評論0 收藏0

    發(fā)表評論

    0條評論

    最新活動
    閱讀需要支付1元查看
    <