成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Vue.js應(yīng)用性能優(yōu)化:第一部分---介紹性能優(yōu)化和懶加載

ZweiZhao / 2962人閱讀

摘要:我的目標是使本系列成為關(guān)于應(yīng)用程序性能的完整指南。代碼分割就是將應(yīng)用程序分割成這些延遲加載的塊??偨Y(jié)延遲加載是提高應(yīng)用程序性能并減少其大小的最佳方法之一。在本系列的下一部分中,我將向您展示如何使用和路由來分割應(yīng)用程序代碼。

當“移動優(yōu)先”(mobile-first)的方式逐漸成為一種標準,而不確定的網(wǎng)絡(luò)環(huán)境因素應(yīng)該始終是我們考慮的一點,因此保持讓應(yīng)用程序快速加載變得越來越困難。在本系列文章中,我將深入研究Vue性能優(yōu)化技術(shù),我們在 Vue Storefront 中已經(jīng)使用了這些技術(shù),您也可以在Vue.js應(yīng)用程序中使用這些技術(shù),使它們能夠立即加載并順利運行。我的目標是使本系列成為關(guān)于Vue應(yīng)用程序性能的完整指南。

Part 1?—?Introduction to performance optimization and lazy loading.

Part 2?—?Lazy loading routes and vendor bundle anti-pattern.

Part 3?—?Lazy loading Vuex modules

Part 4?—?Delivering good waiting experience and lazy loading individual components?—?soon

Part 5?—?Lazy loading libs and finding smaller equivalents?—?soon

Part 6?—?Performance-friendly usage of UI libraries

Part 7?—?Making use of Service Worker cache?—?soon

Part 8?—?Prefetching

Webpack 打包工作原理

本系列的大部分技巧將集中于使我們的JS包更小。要理解這一點,首先我們需要理解 Webpack 是如何打包(bundling)我們所有的文件的。當打包我們的資源時,Webpack 創(chuàng)建了被成為依賴圖(dependency graph)的東西,它是一個基于入口,鏈接我們所有文件的圖。假設(shè)我們在webpack配置中指定了一個名為 main.js 的文件作為入口點,它將是依賴關(guān)系圖的根?,F(xiàn)在,我們將在此文件中導(dǎo)入的每個js模塊將成為圖中的節(jié)點,并且在此節(jié)點中導(dǎo)入的每個模塊都將成為其節(jié)點。Webpack 正是使用這個依賴關(guān)系圖來檢測輸出的包中應(yīng)該包含哪些文件。輸出包只是一個包含依賴關(guān)系圖中所有模塊的 Javascript 文件(或后面的部分將看到多個)。

我們可以圖解這個過程,像這樣:

現(xiàn)在,當我們知道打包是如何工作的,很明顯我們的項目越多,初始的 javascript 包體積會變的越大。包太大,下載和解析的時間就會越長,用戶過很長時間才能看到有意義的東西。用戶等待的時間越長,他/她就越有可能離開我們的網(wǎng)站。

簡而言之,更大的bundle = 更少的用戶。至少在大多數(shù)情況下是這樣。

延遲加載

因此,當我們?nèi)匀恍枰砑有绿匦院透倪M應(yīng)用程序時,我們?nèi)绾文軌驕p少包的大???答案很容易-延遲加載和代碼分割。

顧名思義,延遲加載就是延遲加載應(yīng)用程序的某些部分。換句話說,只有在我們真正需要的時候才加載它們。代碼分割就是將應(yīng)用程序分割成這些延遲加載的塊。

在大多數(shù)情況下,您不需要在用戶訪問您的網(wǎng)站后立即從Javascript文件中獲得所有代碼。即使我們的應(yīng)用程序中會有3個不同的路由,不管用戶最終會在哪個路由上,他/她總是需要下載、解析和執(zhí)行文件中三個路由的代碼,即便是只需要訪問一個路由。多么浪費時間和精力!

延遲加載允許我們分割包(split the bundle),并只提供所需要的部分,這樣用戶就不會浪費時間下載和解析不被使用的代碼。

要查看我們的網(wǎng)站實際使用了多少JavaScript代碼,我們可以到開發(fā)者工具 -> cmd+shift+p -> type coverage -> 點擊 "record"?,F(xiàn)在我們應(yīng)該能夠看到實際使用了多少下載的代碼。

所有標記為紅色的東西都是當前路由上不需要的,可以延遲加載。如果您正在使用源碼映射(source maps ),您可以單擊此列表中的任何文件,查看它的哪些部分沒有被調(diào)用。我們可以看到,即使是 vuejs.org 也有很大的改進空間。

通過延遲加載適當?shù)慕M件和庫,我們設(shè)法將 Vue Storefront 的文件大小減少了60%!

好了,我們知道什么是延遲加載,它非常有用。

現(xiàn)在來看看如何在Vue.js應(yīng)用程序中使用它。

動態(tài)導(dǎo)入 (Dynamic imports)

我們可以輕松地用 webpack dynamic imports 加載應(yīng)用程序的某些部分。讓我們看看它們是如何工作的,以及它們與常規(guī)導(dǎo)入有何不同。

如果我們將以這樣的標準方式導(dǎo)入JS模塊:

// main.js
import ModuleA from "./module_a.js"
ModuleA.doStuff()

它將作為 main.js 的一個節(jié)點添加到依賴關(guān)系圖中,并與之打包在一起。

但是,如果我們僅在某些情況下需要 ModuleA,例如對用戶交互的響應(yīng),那該怎么辦呢?將這個模塊與初始文件打包在一起不是一個好主意,因為可能根本不需要它。我們需要一種方法來告訴應(yīng)用程序何時應(yīng)該下載這段代碼。

這就是動態(tài)導(dǎo)入可以幫助我們的地方!現(xiàn)在看看這個例子:

//main.js
const getModuleA = () => import("./module_a.js")
// 作為對某些用戶交互的響應(yīng)調(diào)用
getModuleA()
  .then({ doStuff } => doStuff())

讓我們快速看看這里發(fā)生了什么:

我們沒有直接導(dǎo)入 module_a.js,而是創(chuàng)建了一個返回 import() 函數(shù)的函數(shù)。現(xiàn)在webpack將動態(tài)導(dǎo)入模塊的內(nèi)容打包到一個多帶帶的文件中,除非函數(shù)被調(diào)用,否則不會導(dǎo)入也不會下載文件。在稍后的代碼中,我們下載了這段可選代碼,作為對某些特定用戶交互的響應(yīng)(如路由更改或單擊)。

通過動態(tài)導(dǎo)入,我們基本上隔離了將添加到依賴關(guān)系圖中的給定節(jié)點(在本例中是 module_a),并在確定需要時下載這一部分(這意味著我們還切斷了在module_a.js中導(dǎo)入的模塊)。

讓我們看另一個例子,它將更好地說明這種機制。

假設(shè)我們有4個文件: main.js, module_a.jsmodule_b.jsmodule_c.js。要了解動態(tài)導(dǎo)入的工作原理,我們只需要 mainmodule_a 的源代碼:

//main.js
import ModuleB from "./mobile_b.js"
const getModuleA = () => import("./module_a.js")
getModuleA()
  .then({ doStuff } => doStuff()
)
//module_a.js
import ModuleC from "./module_c.js"

通過使 module_a 成為一個動態(tài)導(dǎo)入的模塊,我們把 module_a 及其所有的子模塊從依賴圖切割成一部分。當 module_a 被動態(tài)導(dǎo)入時,它與其中導(dǎo)入的模塊一起加載。換句話說,我們只是為依賴關(guān)系圖創(chuàng)建了一個新的入口點。

這就是我們的依賴關(guān)系圖和文件包在給定設(shè)置下的樣子。

延遲加載Vue組件

我們知道什么是延遲加載,以及為什么需要它?,F(xiàn)在看看如何在Vue應(yīng)用程序中使用它。

好消息是它非常簡單,我們可以延遲加載整個SFC(譯者注:Vue Single-File Component -- 單文件組件)以及它的css和html,語法與之前一模一樣!

const lazyComponent = () => import("Component.vue")

這就是你所需要的! 現(xiàn)在只有在請求時才會下載組件。 以下是調(diào)用Vue組件動態(tài)加載的最常用方法:

調(diào)用帶有導(dǎo)入的函數(shù)

const lazyComponent = () => import("Component.vue")
lazyComponent()

組件請求后渲染


請注意,只有當組件被請求要在模板中渲染時,才會調(diào)用 lazyComponent 函數(shù)。
例如下面的代碼:

 

這樣不會動態(tài)導(dǎo)入組件,因為它并沒有添加到DOM中(但是當值變?yōu)閠rue時就會動態(tài)導(dǎo)入,這是一種延遲加載Vue組件的好方法)。

總結(jié)

延遲加載是提高web應(yīng)用程序性能并減少其大小的最佳方法之一。我們學(xué)習(xí)了如何使用Vue組件的延遲加載。在本系列的下一部分中,我將向您展示如何使用 Vue-routerasync 路由來分割Vue應(yīng)用程序代碼。

如果對你有幫助,請關(guān)注【前端技能解鎖】:

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/110215.html

相關(guān)文章

  • 前端每周清單第 10 期:Firefox53、React VR發(fā)布、Microsoft Edge現(xiàn)代

    摘要:新聞熱點國內(nèi)國外,前端最新動態(tài)發(fā)布近日,正式發(fā)布新版本中提供了一系列的特性與問題修復(fù)。而近日正式發(fā)布,其能夠幫助開發(fā)者快速構(gòu)建應(yīng)用。 前端每周清單第 10 期:Firefox53、React VR發(fā)布、JS測試技術(shù)概述、Microsoft Edge現(xiàn)代DOM樹構(gòu)建及性能之道 為InfoQ中文站特供稿件,首發(fā)地址為這里;如需轉(zhuǎn)載,請與InfoQ中文站聯(lián)系。從屬于筆者的 Web 前端入門...

    MingjunYang 評論0 收藏0
  • vue項目搭建以及全家桶的使用詳細教程

    摘要:前言是現(xiàn)階段很流行的前端框架,很多人通過官方文檔的學(xué)習(xí),對的使用都有了一定的了解,但再在項目工程化處理的時候,卻發(fā)現(xiàn)不知道改怎么更好的管理自己的項目,如何去引入一些框架以及全家桶其他框架的使用,以下將詳細地介紹本人在處理工程文件構(gòu)建的過程對 前言 vue是現(xiàn)階段很流行的前端框架,很多人通過vue官方文檔的學(xué)習(xí),對vue的使用都有了一定的了解,但再在項目工程化處理的時候,卻發(fā)現(xiàn)不知道改怎...

    simon_chen 評論0 收藏0
  • vue項目搭建以及全家桶的使用詳細教程

    摘要:前言是現(xiàn)階段很流行的前端框架,很多人通過官方文檔的學(xué)習(xí),對的使用都有了一定的了解,但再在項目工程化處理的時候,卻發(fā)現(xiàn)不知道改怎么更好的管理自己的項目,如何去引入一些框架以及全家桶其他框架的使用,以下將詳細地介紹本人在處理工程文件構(gòu)建的過程對 前言 vue是現(xiàn)階段很流行的前端框架,很多人通過vue官方文檔的學(xué)習(xí),對vue的使用都有了一定的了解,但再在項目工程化處理的時候,卻發(fā)現(xiàn)不知道改怎...

    curlyCheng 評論0 收藏0
  • vue項目搭建以及全家桶的使用詳細教程

    摘要:前言是現(xiàn)階段很流行的前端框架,很多人通過官方文檔的學(xué)習(xí),對的使用都有了一定的了解,但再在項目工程化處理的時候,卻發(fā)現(xiàn)不知道改怎么更好的管理自己的項目,如何去引入一些框架以及全家桶其他框架的使用,以下將詳細地介紹本人在處理工程文件構(gòu)建的過程對 前言 vue是現(xiàn)階段很流行的前端框架,很多人通過vue官方文檔的學(xué)習(xí),對vue的使用都有了一定的了解,但再在項目工程化處理的時候,卻發(fā)現(xiàn)不知道改怎...

    xi4oh4o 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<