什么是diff算法?


我們在進行dom操作的時候可能會出現需要更新某一個dom元素,但如果不更新整個組件就無法生效,其實我們使用diff算法配合虛擬dom即可實現。

  虛擬DOM

  本質上就是一個JS對象,用來描述你希望在屏幕上看到的內容 

虛擬dom

  Diff算法

  執行過程

  初次渲染時,React會根據初始化的state(model),創建一個虛擬DOM對象(樹) 根據虛擬DOM生成真正的DOM,渲染到頁面 當數據變化后(setState()),會重新根據新的數據,創建新的虛擬DOM對象(樹) 與上一次得到的虛擬DOM對象,使用Diff算法比對(找不同),得到需要更新的內容 最終,React只將變化的頁游內容更新(patch)到DOM中,重新渲染到頁面 

diff算法

  代碼演示

  組件render()調用后,根據狀態和JSX結構生成虛擬DOM對象(renderwww.sangpi.com()方法的調用並不意味着瀏覽器進行渲染,render方法調用時意味着Diff算法開始比對了) 示例中,只更新p元素的文本節點內容 初次渲染的DOM對象 

代碼演示

  數據更新之后的虛擬DOM對象

頁游代碼演示2


  工作角度:應用第一,原理第二

  原理有助於更好的理解React的自身運行機制

  setState() 異步更新數據 父組件更新導致子組件更新,純組件提升性能 思路清晰簡單為前提,虛擬DOM和Diff保效率(渲染變化的組件) 虛擬DOM -> state + JSX 虛擬DOM最大的特點是 脫離了瀏覽器的束縛,也就是意味着只要是能支持js的地方都可以用到react,所以為什么說react是可以進行跨平台的開發 以上就是關於dom和diff算法的介紹了,希望能幫到大家。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM