千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > web前端技巧-DOM和Diff算法你應該知道的那些事

web前端技巧-DOM和Diff算法你應該知道的那些事

來源:千鋒教育
發(fā)布人:小千
時間: 2021-06-17 13:31:00 1623907860

      我們在進行dom操作的時候可能會出現(xiàn)需要更新某一個dom元素,但如果不更新整個組件就無法生效,其實我們使用diff算法配合虛擬dom即可實現(xiàn),下面小千就來給大家介紹一下。

      虛擬DOM

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

虛擬dom

      Diff算法

      執(zhí)行過程

      初次渲染時,React會根據(jù)初始化的state(model),創(chuàng)建一個虛擬DOM對象(樹)

      根據(jù)虛擬DOM生成真正的DOM,渲染到頁面

      當數(shù)據(jù)變化后(setState()),會重新根據(jù)新的數(shù)據(jù),創(chuàng)建新的虛擬DOM對象(樹)

      與上一次得到的虛擬DOM對象,使用Diff算法比對(找不同),得到需要更新的內容

      最終,React只將變化的內容更新(patch)到DOM中,重新渲染到頁面

diff算法

      代碼演示

      組件render()調用后,根據(jù)狀態(tài)和JSX結構生成虛擬DOM對象(render()方法的調用并不意味著瀏覽器進行渲染,render方法調用時意味著Diff算法開始比對了)

      示例中,只更新p元素的文本節(jié)點內容

      初次渲染的DOM對象

代碼演示

      數(shù)據(jù)更新之后的虛擬DOM對象

代碼演示2

      小結

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

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

      setState() 異步更新數(shù)據(jù)

      父組件更新導致子組件更新,純組件提升性能

      思路清晰簡單為前提,虛擬DOM和Diff保效率(渲染變化的組件)

      虛擬DOM -> state + JSX

      虛擬DOM最大的特點是 脫離了瀏覽器的束縛,也就是意味著只要是能支持js的地方都可以用到react,所以為什么說react是可以進行跨平臺的開發(fā)

      以上就是關于dom和diff算法的介紹了,最后歡迎對前端開發(fā)感興趣的同學來到千鋒web前端培訓班參加我們的前端培訓課程的學習,全程名師面授確保教學質量,現(xiàn)在咨詢還有免費學習資料可以領取,趕緊來了解一下吧。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉載。
10年以上業(yè)內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
oracle怎么樣實現(xiàn)數(shù)據(jù)庫跨機房同步?

一、oracle怎么樣實現(xiàn)數(shù)據(jù)庫跨機房同步除了使用第三方工具,Oracle提供了extended cluster可以實現(xiàn)類似的功能,使用Oracle RAC + ASM。簡單說下...詳情>>

2023-10-14 01:57:43
web網(wǎng)站性能測試的常用指標有哪些?

一、頁面加載時間頁面加載時間是衡量網(wǎng)站性能的重要指標之一,它指的是從用戶請求一個頁面到頁面完全加載完成所需的時間。頁面加載時間的長短直...詳情>>

2023-10-14 01:50:34
MySQL索引為什么能讓查詢效率提高?

一、MySQL索引為什么能讓查詢效率提高DB在執(zhí)行一條Sql語句的時候,默認的方式是根據(jù)搜索條件進行全表掃描。如果我們對某一字段增加索引,查詢時...詳情>>

2023-10-14 01:38:15
什么是面向云原生系統(tǒng)的智能運維?

一、云原生系統(tǒng)概述云原生系統(tǒng)是指在云計算環(huán)境下構建和運行的應用程序系統(tǒng),具備高可用、彈性擴展、靈活部署和自動化管理等特點。它采用容器化...詳情>>

2023-10-14 01:25:33
怎么提升excel數(shù)據(jù)表訪問運算速度?

一、怎么提升excel數(shù)據(jù)表訪問運算速度目前版本Excel最大列數(shù)為16384,沒有10w加。運算速度和Excel中是否有公式、公式的復雜度、對象的對少、格...詳情>>

2023-10-14 01:22:48