真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

javascript的虛擬DOM怎么進(jìn)化為真實(shí)DOM

本篇內(nèi)容主要講解“javascript的虛擬DOM怎么進(jìn)化為真實(shí)DOM”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“javascript的虛擬DOM怎么進(jìn)化為真實(shí)DOM”吧!

我們注重客戶提出的每個(gè)要求,我們充分考慮每一個(gè)細(xì)節(jié),我們積極的做好成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)服務(wù),我們努力開拓更好的視野,通過不懈的努力,成都創(chuàng)新互聯(lián)公司贏得了業(yè)內(nèi)的良好聲譽(yù),這一切,也不斷的激勵(lì)著我們更好的服務(wù)客戶。 主要業(yè)務(wù):網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)站設(shè)計(jì),小程序制作,網(wǎng)站開發(fā),技術(shù)開發(fā)實(shí)力,DIV+CSS,PHP及ASP,ASP.Net,SQL數(shù)據(jù)庫的技術(shù)開發(fā)工程師。

前言

Vue和React的Render函數(shù)中都涉及到了Virtual DOM的概念,Virtual  DOM也是性能優(yōu)化上的重要一環(huán),同時(shí)突破了直接操作真實(shí)DOM的瓶頸,本文帶著以下幾個(gè)問題來闡述Virtual DOM。

1.為什么要操作虛擬 DOM?

2.什么是虛擬 DOM?

3.手把手教你實(shí)現(xiàn)虛擬 DOM 渲染真實(shí) DOM

希望閱讀本文之后,能夠讓你深入的了解虛擬 DOM并且在開發(fā)和面試中收益。

為什么要操作虛擬 DOM

為了幫助我們更好的理解為什么要操作虛擬 DOM,我們先從瀏覽器渲染[1]一個(gè) HTML 文件需要做哪些事情說起:

javascript的虛擬DOM怎么進(jìn)化為真實(shí)DOM

瀏覽器渲染機(jī)制大致可以分為以下 5 步走:

1.創(chuàng)建 DOM tree

2.創(chuàng)建 Style Rules

3.構(gòu)建 Render tree

4.布局 Layout

5.繪制 Painting

我們過去使用原生JavaScript和jquery去操作真實(shí)DOM的時(shí)候,瀏覽器會(huì)從構(gòu)建 DOM? 開始從頭到尾的執(zhí)行一遍渲染的流程。

在一次開發(fā)中,假如產(chǎn)品告訴你一個(gè)需求,你需要在一次操作中更新10個(gè)DOM節(jié)點(diǎn),理想狀態(tài)是瀏覽器一次性構(gòu)建完DOM樹,再執(zhí)行后續(xù)操作。但瀏覽器沒這么智能,收到第一個(gè)更新  DOM 請求后,并不知道后續(xù)還有9次更新操作,因此會(huì)馬上執(zhí)行流程,最終執(zhí)行 10 次流程。

過了一會(huì)產(chǎn)品經(jīng)理把你叫過去和你說把需求改一下,此時(shí)你又需要操作一次 DOM 的更新,那么這個(gè)時(shí)候之前做的 10 次 DOM  操作就是白白浪費(fèi)性能,浪費(fèi)感情。

即使計(jì)算機(jī)硬件一直在更新迭代,但是操作DOM的代價(jià)仍舊是昂貴的,頻繁操作 DOM 還是會(huì)出現(xiàn)頁面卡頓,影響用戶的體驗(yàn)。真實(shí)的 DOM  節(jié)點(diǎn),哪怕一個(gè)最簡單的 div 也包含著很多屬性,可以打印出來直觀感受一下:

javascript的虛擬DOM怎么進(jìn)化為真實(shí)DOM

如此多的屬性,如果每次對 DOM 結(jié)構(gòu)都進(jìn)行更新,一次,兩次,三次...一百次....一千次...,可想而知,是多么龐大的數(shù)據(jù)量。

因此虛擬DOM就是為了解決這個(gè)瀏覽器性能問題而被設(shè)計(jì)出來的。例如前面的例子,假如一次操作中有 10 次更新 DOM  的動(dòng)作,虛擬DOM不會(huì)立即操作DOM,而是將這 10 次更新 DOM  的動(dòng)作通過Diff算法最終生成一個(gè)js對象,然后通知瀏覽器去執(zhí)行一次繪制工作,這樣可以避免大量的無謂的計(jì)算量。

什么是虛擬 DOM

虛擬 DOM[2]就是我們上面所說的js對象。

其本質(zhì)上就是在JS和DOM之間做了一個(gè)緩存??梢灶惐?CPU 和硬盤,既然硬盤這么慢,我們就在它們之間加個(gè)緩存:既然 DOM 這么慢,我們就在它們 JS  和 DOM 之間加個(gè)緩存。CPU(JS)只操作內(nèi)存(Virtual DOM),最后的時(shí)候再把變更寫入硬盤(DOM),直接操作內(nèi)存中的 JS  對象的速度顯然要更快。

function vnode(tag, data, key, children, text) {     return {         tag,         data,         key,         children,         text     } }

舉個(gè)栗子:

假如我們有這樣的一個(gè) DOM 樹

   前端簡報(bào)   
  • vue
  •  

    那么,我們怎么用 js 的對象來對應(yīng)到這個(gè)樹呢?

    {     tag: 'ul',        // 元素標(biāo)簽     data: {           // 屬性         class: 'list'     },     key: '',     text: '',  // 文本內(nèi)容     children: [         {             tag: "li",             data: {                 class: "item"             },             key: '',             text: '',             children: [                 {                     tag: undefined,                     data: undefined,                     key: undefined,                     text: '前端簡報(bào)',                     children: []                 }             ]         },         {             tag: "li",             data: "",             key: '',             text: '',             children: [                 {                     tag: undefined,                     data: undefined,                     key: undefined,                     text: 'vue',                     children: []                 }             ]         }     ]       // 子元素 }

    由此可知:DOM tree的信息都可以用JavaScript對象來表示,反過來,我們也可以用  JavaScript對象表示的樹結(jié)構(gòu)來構(gòu)建一棵真正的DOM樹。

    實(shí)現(xiàn)虛擬 DOM 渲染真實(shí) DOM

    有了JavaScript對象之后如何轉(zhuǎn)化為真實(shí)的 DOM 樹結(jié)構(gòu)呢?

    ul 和 li 在 js 對象中,頁面上并沒有此結(jié)構(gòu),所以我們需要把ul和li轉(zhuǎn)化為和

    標(biāo)簽

    而文本標(biāo)簽我們定義 Vnode 為:

    {    tag: undefined,    data: undefined,    key: undefined,    text: 'vue',    children: [] }

    故可以判斷tag的類型來確定創(chuàng)建元素的類型.

    function createElm(vnode) {     let { tag, data, children, key, text } = vnode;      if (typeof tag == "string") {         vnode.el = document.createElement(tag);  //創(chuàng)建元素放到vnode.el上         children.forEach(child => {             vnode.el.appendChild(createElm(child))         })     } else {         vnode.el = document.createTextNode(text);  //創(chuàng)建文本     }     return vnode.el }

    如果子節(jié)點(diǎn)存在并且也是虛擬DOM的話,我們通過遞歸調(diào)用創(chuàng)建子節(jié)點(diǎn)。

    javascript的虛擬DOM怎么進(jìn)化為真實(shí)DOM

    創(chuàng)建 DOM 樹結(jié)構(gòu)之后我們需要設(shè)置節(jié)點(diǎn)的屬性,即處理虛擬 DOM 中的data屬性。

    function updateProperties(vnode) {     let el = vnode.el;     let newProps = vnode.data || {};     for (let key in newProps) {         if (key == "style") {             for (let styleName in newProps.style) {                 el.style[styleName] = newProps.style[styleName];             }         } else if (key == "class") {             el.className = newProps.class;         } else {             el.setAttribute(key, newProps[key]);         }     } }

    在我們創(chuàng)建元素標(biāo)簽之后調(diào)用updateProperties方法即可

    javascript的虛擬DOM怎么進(jìn)化為真實(shí)DOM

    把上面創(chuàng)建出來的真實(shí) DOM 結(jié)構(gòu) vnode.el 添加到文檔當(dāng)中即可呈現(xiàn)出我們需要的真實(shí) DOM 結(jié)構(gòu)

    let parentElm = document.getElementById("app").parentNode; 獲取之前app的父親body parentElm.insertBefore(createElm(vnode), document.getElementById("app").nextSibling); //body里在老的app后面插入真實(shí)dom parentElm.removeChild(document.getElementById("app")); //刪除老的節(jié)點(diǎn)

     javascript的虛擬DOM怎么進(jìn)化為真實(shí)DOM

    總結(jié)

    以上就是本文的全部內(nèi)容,我想我們現(xiàn)在應(yīng)該了解什么是虛擬DOM的概念了以及虛擬DOM是如何實(shí)現(xiàn)真實(shí)DOM渲染的。其中用到了主要用到了子節(jié)點(diǎn)的遞歸。

    到此,相信大家對“javascript的虛擬DOM怎么進(jìn)化為真實(shí)DOM”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!


    當(dāng)前名稱:javascript的虛擬DOM怎么進(jìn)化為真實(shí)DOM
    網(wǎng)頁地址:http://weahome.cn/article/jhgise.html

    其他資訊

    在線咨詢

    微信咨詢

    電話咨詢

    028-86922220(工作日)

    18980820575(7×24)

    提交需求

    返回頂部