欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談Vue SSR中的Bundle的具有使用

 更新時間:2019年11月21日 10:22:23   作者:YYDev  
這篇文章主要介紹了淺談Vue SSR中的Bundle的具有使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

寫過Vue SSR的都知道,Vue通過提供server和client的webpack插件生成bundle josn,從而實現(xiàn)類似服務(wù)端的熱更以及客戶端資源的優(yōu)化注入。那么這兩個個bundle到底有什么神奇的呢?OK,話不多說,進入正題

客戶端 vue-ssr-client-manifest.json

首先看看客戶端的json,明顯看到,里面借助webpack插件,把spa用到的文件進行了分類, publicPath 是公共路徑,all 是所有的文件, initial 是入口文件依賴的js和css, async 是首屏不需要的異步的js,分析這些出來有什么用呢,主要是用來優(yōu)化生成的html的資源注入,這個在后面會講到

服務(wù)端 vue-ssr-server-bundle.json

然后我們再康康服務(wù)端生成的json, entry 是服務(wù)款入口的文件, files 是服務(wù)端依賴的文件列表, maps 是sourcemaps文件列表,這里暫時是空

如果把files展開,會看到里面是一堆文件列表,文件名跟key一樣,然后value里面,對的,你沒看錯,是一段js,里面就是服務(wù)端渲染需要的代碼,那道理我都懂,為什么有這段就可以實現(xiàn)服務(wù)端代碼的熱更以及sourcemap的定位呢

服務(wù)端的熱更和sourcemap

帶著這個問題,我去看了一下vue服務(wù)端的源碼,左邊框的三個文件就是實現(xiàn)這些神奇效果的關(guān)鍵之處了,其中右邊框的entry、files就是我們上面服務(wù)端對應(yīng)的json

接下來我們再去看看createBundleRunner里面這個方法,最關(guān)鍵是evaluateModule 里面調(diào)用getCompiledScript這個方法,其中evaluateModule 還會把執(zhí)行的結(jié)果緩存到evaluatedFiles里面去

getCompiledScript里面通過調(diào)用vm.Scirpt把我們在entry里面的代碼丟進vm創(chuàng)建的沙箱里面,同時也是要compiledScripts把生成的script片段緩存起來

vm.Script創(chuàng)建沙箱,我們還可以傳入sandbox上下文,如果entry創(chuàng)建的沙箱依賴其他文件,還可以遞歸創(chuàng)建沙箱,通過這樣做,我們就可以監(jiān)聽服務(wù)端文件變化的時候創(chuàng)建新的服務(wù)端json,再創(chuàng)建新的沙箱來執(zhí)行,從而達到nodejs熱更的效果

其中我們知道runInNewContext決定是否創(chuàng)建新的上下文,我們知道如果設(shè)置為false,則會使用runInThisContext創(chuàng)建沙箱,但是會容易污染全局global,如果我們使用runInNexContext來創(chuàng)建,同時傳入我們預(yù)先傳入的sandbox,就可以隔離上下文,但是這樣有個壞處,就是創(chuàng)建新的上下文會有一定的資源消耗,

如果我們使用once來創(chuàng)建,就不會每個請求都創(chuàng)建新的隔離上下文,而是創(chuàng)建一個新的隔離上下文公用,這樣就可以最大限度避免V8創(chuàng)建的消耗,可以看到,只有在沒有runner的情況下才才會創(chuàng)建sandbox

至于sourcemap,通過使用mozilla這個 source-map npm庫,在堆棧出錯的時候,把錯誤的文件和函數(shù)進去,通過消費sourcemap來還原定位源文件的具體的位置和行數(shù) 可以說,腦洞真的很大,但這就完了嗎,不止~

前面我們只講了服務(wù)端的json,那客戶端也生成了一份呢,那個有什么用呢?我們再次進入vue源碼去挖掘, 很快就找到了答案

客戶端的注入優(yōu)化

我們知道服務(wù)端渲染會返回一個html,然后接下來客戶端會走一次hydration,客戶端需要的文件,例如js和css,我們需要在寫在html里面,然后通過http去請求文件回來,不然怎么hydration啊

但這里有個維度,哪些是入口文件,哪些是異步文件,vue服務(wù)端自帶client-plugin已經(jīng)幫我們抽離出來了,OK,回到我們構(gòu)建html,對于入口文件和css,我們會做preload的優(yōu)化,對于異步的會做prefetch優(yōu)化,同時對于入口的js還會做個script標簽的defer加載提高并發(fā)數(shù)

總結(jié)

Vue SSR就是這么巧妙地利用兩個webpack插件提取項目的關(guān)鍵信息生成bundle,從而達到服務(wù)器熱更以及前端加載優(yōu)化,真的可以說腦洞很大

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue加載組件、動態(tài)加載組件的幾種方式

    Vue加載組件、動態(tài)加載組件的幾種方式

    組件是Vue.js最強大的功能之一。組件可以擴展HTML元素,封裝可重用的代碼。這篇文章通過實例代碼給大家介紹了Vue加載組件、動態(tài)加載組件的幾種方式,需要的朋友參考下吧
    2018-08-08
  • vue前端實現(xiàn)導(dǎo)出頁面為word的兩種方法代碼

    vue前端實現(xiàn)導(dǎo)出頁面為word的兩種方法代碼

    在前端開發(fā)中我們常常需要將頁面頁面為word文件,這篇文章主要給大家介紹了關(guān)于vue前端實現(xiàn)導(dǎo)出頁面為word的兩種方法,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-04-04
  • 超簡單的Vue.js環(huán)境搭建教程

    超簡單的Vue.js環(huán)境搭建教程

    這篇文章主要為大家分享了一份超簡單的Vue.js環(huán)境搭建教程,幫助大家快速搭建vue環(huán)境,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • Element?Plus修改表格行和單元格樣式詳解

    Element?Plus修改表格行和單元格樣式詳解

    在使用Element Plus中的table組件展示數(shù)據(jù)時,由于需要對表格行內(nèi)數(shù)據(jù)的數(shù)據(jù)進行修改,下面這篇文章主要給大家介紹了關(guān)于Element?Plus修改表格行和單元格樣式的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • vue.js指令v-for使用及索引獲取

    vue.js指令v-for使用及索引獲取

    這篇文章主要為大家詳細介紹了vue.js中v-for使用及索引獲取,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • vue項目中圖片選擇路徑位置static或assets的區(qū)別及說明

    vue項目中圖片選擇路徑位置static或assets的區(qū)別及說明

    這篇文章主要介紹了vue項目中圖片選擇路徑位置static或assets的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue實現(xiàn)圖書管理案例

    Vue實現(xiàn)圖書管理案例

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)圖書管理案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • Vue如何動態(tài)修改el-table的某列數(shù)據(jù)

    Vue如何動態(tài)修改el-table的某列數(shù)據(jù)

    這篇文章主要介紹了Vue如何動態(tài)修改el-table的某列數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 詳解Vue的常用指令v-if, v-for, v-show,v-else, v-bind, v-on

    詳解Vue的常用指令v-if, v-for, v-show,v-else, v-bind, v-on

    Vue.js的指令是以v-開頭的,它們作用于HTML元素,指令提供了一些特殊的特性。這篇文章主要介紹了Vue的常用指令v-if, v-for, v-show,v-else, v-bind, v-on 的相關(guān)知識,需要的朋友可以參考下
    2018-10-10
  • 手把手教你Vue3實現(xiàn)路由跳轉(zhuǎn)

    手把手教你Vue3實現(xiàn)路由跳轉(zhuǎn)

    Vue Router是Vue.js的官方路由器,它與Vue.js核心深度集成,使使用Vue.js構(gòu)建單頁應(yīng)用程序變得輕而易舉,下面這篇文章主要給大家介紹了關(guān)于Vue3實現(xiàn)路由跳轉(zhuǎn)的相關(guān)資料,需要的朋友可以參考下
    2022-08-08

最新評論