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

資訊專欄INFORMATION COLUMN

談?wù)勄岸斯こ袒?js加載

paulli3 / 1694人閱讀

摘要:當(dāng)年的加載在沒有前端工程化之前,基本上是我們是代碼一把梭,把所需要的庫和自己的代碼堆砌在一起,然后自上往下的引用就可以了。而且對(duì)于前后端的技術(shù)要求較高,所以對(duì)于項(xiàng)目未必是最有效的方案。

當(dāng)年的 js 加載

在沒有 前端工程化之前,基本上是我們是代碼一把梭,把所需要的庫和自己的代碼堆砌在一起,然后自上往下的引用就可以了。
那個(gè)時(shí)代我們沒有公用的cdn,也沒有什么特別好的方法來優(yōu)化加載js的速度。最多用以下幾個(gè)方案。

可用的性能方案

可以在代碼某些需要js的時(shí)候去使用 loadjs 來動(dòng)態(tài)加載 js 庫。這樣就不會(huì)出現(xiàn)開始時(shí)候加載大量js文件。

再大點(diǎn)的項(xiàng)目可能用一下 Nginx ngx_http_concat_module 模塊來合并多個(gè)文件在一個(gè)響應(yīng)報(bào)文中。也就是再加載多個(gè)小型 js 文件時(shí)候合并為一個(gè) js 文件。

BigPipe 技術(shù)也是可以對(duì)頁面分塊來進(jìn)行優(yōu)化的,但是因?yàn)榕c本文關(guān)系不大,方案也沒有通用化和規(guī)范化,加上本人其實(shí)沒有深入了解所不進(jìn)行深入介紹,如果先了解可以參考 新版賣家中心 Bigpipe 實(shí)踐(一) 以及 新版賣家中心 Bigpipe 實(shí)踐(二)。

當(dāng)然那個(gè)時(shí)期的代碼也沒有像現(xiàn)在的前端的代碼量和復(fù)雜度那么高。

Webpack 之后的js加載

與其說 Webpack 是一個(gè)模塊打包器,倒不如說 Webpack 是一份前端規(guī)范。

需要庫沒有被大量使用情況

對(duì)于我們代碼中所需要的代碼庫沒有大量使用,比如說某種組件庫我們僅僅只使用了 2、3個(gè)組件的情況下。我們更多需要按需加載功能。
比方說在 MATERIAL-UI 我們可以用

import TextField from "@material-ui/core/TextField";
import Popper from "@material-ui/core/Popper";
import Paper from "@material-ui/core/Paper";
import MenuItem from "@material-ui/core/MenuItem";
import Chip from "@material-ui/core/Chip";

代替

import {
  TextField,
  Popper,
  Paper,
  MenuItem,
  Chip
} from "@material-ui"

這樣就實(shí)現(xiàn)了按需加載,而不是動(dòng)輒需要整個(gè)組件庫。但是這樣的代碼中這樣代碼并不好書寫。我們就需要一個(gè)幫助我們轉(zhuǎn)換代碼的庫。這可以參考 Babel 插件手冊 以及 簡單實(shí)現(xiàn)項(xiàng)目代碼按需加載 來實(shí)現(xiàn)我們的需求。

需要庫大量被使用情況

如果我們的庫被當(dāng)前的項(xiàng)目大量使用了,按需加載其實(shí)就未必是最好的方法了,如果我們的服務(wù)器不是特別好的情況下我們可以使用 Webpack 的 externals 配置來優(yōu)化項(xiàng)目的js。就簡單的對(duì) externals 配置簡單說明一下。externals其實(shí)是在全局中的得到庫文件。

  // 頁面中使用 cdn,這樣的話,我們就會(huì)在 window 中得到 jQuery
  // 也就是 global.JQuery 瀏覽器中 global === window
  

  // 在項(xiàng)目中導(dǎo)入 jquery 使用
  import $ from "jquery";

  // 配置中 左邊是 配置的 jquery 告訴 Webpack 不需要導(dǎo)入
  // 配置中 右邊是 配置的 JQuery 告訴 Webpack 記載 jquery 時(shí)候使用 global.JQuery
  externals: {
    jquery: "jQuery"
  }

但是使用 externals 曾遇到這樣的情況。我在使用 material-ui 組件庫時(shí)候發(fā)現(xiàn)該庫在全局導(dǎo)出的代碼是 material-ui。
也就是:

  externals: {
    "@material-ui/core": "material-ui"
  }

此時(shí)會(huì)發(fā)生導(dǎo)入錯(cuò)誤,錯(cuò)誤原因?yàn)? window.material-ui。
本來我是想要引入material-ui,卻 - 符號(hào)變?yōu)榱藴p號(hào)。
本來想要利用用 ["material-ui"] 來替換,卻發(fā)現(xiàn)行不通: windows.["material-ui"]
解決方法:

  externals: {
    "@material-ui/core": "window["material-ui"]"
  }

因?yàn)?window 對(duì)象有自己引用自己,所以 window === window.window.window。所以代碼為 window.window["material-ui"]??梢詤⒖?MDN Window.window

上文中的性能優(yōu)化方案依然可用 loadjs 動(dòng)態(tài)加載

在當(dāng)前所需要 js 文件不需要大量使用同時(shí)需要的 js 文件是不需要開始時(shí)加載(如 React, React-Router 一類)的時(shí)候我們依然可以使用loadjs來加載(比如說 圖標(biāo)庫一類,只在某一些頁面使用)。

合并多個(gè)小型 js

對(duì)于在 HTTP2 中合并多個(gè) 小js文件未必好。因?yàn)樵?HTTP2 中,HTTP 請求是廉價(jià)的,合并便不再顯得有優(yōu)勢。

BigPipe 方案

當(dāng)然了,BigPipe 方案不是針對(duì)單頁面應(yīng)用程序。而且對(duì)于前后端的技術(shù)要求較高,所以對(duì)于項(xiàng)目未必是最有效的方案。

其他

現(xiàn)如今也可以使用一些其他的方法。例如 Service Worker,Wasm 等一系列方案。不知道還有什么其他方法,也可以介紹給我。

參考文檔

新版賣家中心 Bigpipe 實(shí)踐(一)
新版賣家中心 Bigpipe 實(shí)踐(二)
Babel 插件手冊
簡單實(shí)現(xiàn)項(xiàng)目代碼按需加載
MDN Window.window

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

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

相關(guān)文章

  • 2017年五月前端面試題目的總結(jié)

    摘要:持續(xù)心累的找工作階段算是結(jié)束了,不同公司對(duì)面試的知識(shí)側(cè)重點(diǎn)不同,整體的感受就是大公司可能更偏向一些基礎(chǔ)或者原理布局一些經(jīng)典算法方面?,F(xiàn)將我在面試過程遇到的問題總結(jié)下。目前先傳題目答案整理好之后再發(fā)布出來。 持續(xù)心累的找工作階段算是結(jié)束了,不同公司對(duì)面試的知識(shí)側(cè)重點(diǎn)不同,整體的感受就是:大公司可能更偏向一些JS基礎(chǔ)或者原理、html布局、一些經(jīng)典算法方面。小公司的面試更加側(cè)重對(duì)經(jīng)驗(yàn)和細(xì)節(jié)...

    warkiz 評(píng)論0 收藏0
  • 2017年五月前端面試題目的總結(jié)

    摘要:持續(xù)心累的找工作階段算是結(jié)束了,不同公司對(duì)面試的知識(shí)側(cè)重點(diǎn)不同,整體的感受就是大公司可能更偏向一些基礎(chǔ)或者原理布局一些經(jīng)典算法方面?,F(xiàn)將我在面試過程遇到的問題總結(jié)下。目前先傳題目答案整理好之后再發(fā)布出來。 持續(xù)心累的找工作階段算是結(jié)束了,不同公司對(duì)面試的知識(shí)側(cè)重點(diǎn)不同,整體的感受就是:大公司可能更偏向一些JS基礎(chǔ)或者原理、html布局、一些經(jīng)典算法方面。小公司的面試更加側(cè)重對(duì)經(jīng)驗(yàn)和細(xì)節(jié)...

    dreamGong 評(píng)論0 收藏0
  • 2017年五月前端面試題目的總結(jié)

    摘要:持續(xù)心累的找工作階段算是結(jié)束了,不同公司對(duì)面試的知識(shí)側(cè)重點(diǎn)不同,整體的感受就是大公司可能更偏向一些基礎(chǔ)或者原理布局一些經(jīng)典算法方面?,F(xiàn)將我在面試過程遇到的問題總結(jié)下。目前先傳題目答案整理好之后再發(fā)布出來。 持續(xù)心累的找工作階段算是結(jié)束了,不同公司對(duì)面試的知識(shí)側(cè)重點(diǎn)不同,整體的感受就是:大公司可能更偏向一些JS基礎(chǔ)或者原理、html布局、一些經(jīng)典算法方面。小公司的面試更加側(cè)重對(duì)經(jīng)驗(yàn)和細(xì)節(jié)...

    liangzai_cool 評(píng)論0 收藏0
  • 談?wù)?/em>前后端的分工協(xié)作

    摘要:針對(duì)上面看到的問題,現(xiàn)在也有一些團(tuán)隊(duì)在嘗試前后端之間加一個(gè)中間層比如淘寶的。淘寶有很多類似的文章,這里不贅述。淘寶團(tuán)隊(duì)做了兩套接口文檔的維護(hù)工具,以及,不知道有沒有對(duì)外開放,兩個(gè)東西都是基于的一個(gè)嘗試,各有優(yōu)劣。 原文出處: 小胡子哥的博客(@Barret李靖) 前后端分工協(xié)作是一個(gè)老生常談的大話題,很多公司都在嘗試用工程化的方式去提升前后端之間交流的效率,降低溝通成本,并且也開發(fā)了...

    Scholer 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<