久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > web前端技巧-DOM和Diff算法你應(yīng)該知道的那些事

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

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

      我們?cè)谶M(jìn)行dom操作的時(shí)候可能會(huì)出現(xiàn)需要更新某一個(gè)dom元素,但如果不更新整個(gè)組件就無(wú)法生效,其實(shí)我們使用diff算法配合虛擬dom即可實(shí)現(xiàn),下面小千就來(lái)給大家介紹一下。

      虛擬DOM

      本質(zhì)上就是一個(gè)JS對(duì)象,用來(lái)描述你希望在屏幕上看到的內(nèi)容

虛擬dom

      Diff算法

      執(zhí)行過(guò)程

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

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

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

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

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

diff算法

      代碼演示

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

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

      初次渲染的DOM對(duì)象

代碼演示

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

代碼演示2

      小結(jié)

      工作角度:應(yīng)用第一,原理第二

      原理有助于更好的理解React的自身運(yùn)行機(jī)制

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

      父組件更新導(dǎo)致子組件更新,純組件提升性能

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

      虛擬DOM -> state + JSX

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

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

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

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

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

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

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

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

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

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

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

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

2023-10-14 01:22:48
快速通道