摘要:還會(huì)生成一個(gè)存放公共樣式的文件,在首次打開(kāi)的時(shí)候就加載完畢配置優(yōu)化隱藏控制臺(tái)信息在文件下補(bǔ)充代碼不顯示控制臺(tái)打印信息隱藏源碼在下的里改為即可。當(dāng)再次時(shí)會(huì)生成文件在控制臺(tái)的可以看到加載的文件優(yōu)化效果明顯,單個(gè)文件至少能縮小一半以上。
生產(chǎn)環(huán)境
平時(shí)我們開(kāi)發(fā)時(shí),npm run dev的環(huán)境是開(kāi)發(fā)環(huán)境;而部署到線上時(shí),npm run build的環(huán)境是生產(chǎn)環(huán)境,代碼會(huì)被打包,放到新生成的dist文件夾下;
圖標(biāo)資源等會(huì)被轉(zhuǎn)為base64,當(dāng)圖片小于一定的大小時(shí),圖片就會(huì)被轉(zhuǎn)為base64,這個(gè)大小可以在webpack配置里設(shè)置,在webpack.base.conf.js下:
//圖片壓縮 new ImageminPlugin({ disable: process.env.NODE_ENV !== "production", // Disable during development pngquant: { quality: "95-100" } }),
但是有個(gè)注意點(diǎn)就是用base64轉(zhuǎn)過(guò)的圖標(biāo)會(huì)比原來(lái)的那個(gè)圖的大小大30%~40%(可以將你圖片轉(zhuǎn)成的base64然后保存成文本對(duì)比圖片的大小)
每個(gè)vue文件中的js和css都會(huì)被壓縮然后多帶帶打包成一個(gè)js, 每次打開(kāi)一個(gè)頁(yè)面,就會(huì)相應(yīng)的去加載那個(gè)js文件;
還會(huì)生成app.js, vendor.js, manifest.js
每當(dāng)我們點(diǎn)擊一個(gè)頁(yè)面就會(huì)去加載一個(gè)js文件(第二次點(diǎn)擊讀的就是緩存),這個(gè)js文件就是webpack打包的關(guān)于這個(gè)頁(yè)面的壓縮代碼。
還會(huì)生成一個(gè)存放公共樣式的css文件,在首次打開(kāi)的時(shí)候就加載完畢
配置優(yōu)化隱藏控制臺(tái)信息
在webpack.prod.conf.js文件下補(bǔ)充代碼:
new webpack.optimize.UglifyJsPlugin({ compress: { warnings: false, /*不顯示控制臺(tái)打印信息*/ drop_debugger: true, drop_console: true, pure_funcs: ["console.log"] }, sourceMap: false })
隱藏源碼:
在config/index.js下的build里:
productionSourceMap: true改為productionSourceMap:false即可。
開(kāi)啟gZip壓縮
在config/index.js中:
將false改為true即可。
productionGzip: true
當(dāng)再次npm run build時(shí)會(huì)生成.gz文件:
在控制臺(tái)的network可以看到加載的js文件
優(yōu)化效果明顯,單個(gè)js文件至少能縮小一半以上。
代碼優(yōu)化代碼優(yōu)化其實(shí)要試具體項(xiàng)目而定。
路由肯定要按需加載
component: resolve => require(["path/component.name"], resolve)
如果組件在多個(gè)地方引用到,那么最好是將組件抽成公共組件,在main.js中注冊(cè)全局組件
Vue.component("component-name", componentName)
這樣組件可在全局直接引用,不用每次先import又局部注冊(cè)。
這樣做的目的也是為了縮小js文件的體積,當(dāng)你的組件在三個(gè)地方用到而你分別引入了三次,打包的時(shí)候你的組件代碼會(huì)被壓縮到三個(gè)不同的js文件中,也就是被壓縮了三次;如果注冊(cè)為全局組件,則代碼只會(huì)被壓縮到app.js中(只被壓縮一次)
公共的函數(shù)和公共的css文件也是同樣的道理
可以將你的公共樣式文件在main.js中引入,至于公共函數(shù)的話,可以掛在到vue下,全局可調(diào)用
Vue.prototype.functionName = functionName
圖片的大小
圖片的大小太大直接影響js文件的大小,所以壓縮圖片是很必要的。如果UI沒(méi)有幫我們壓我們就自己壓。http://tinypng.com/
結(jié)語(yǔ)為了縮小項(xiàng)目的體積,幾kb都要爭(zhēng)取能減少就減少的。盡量將能抽取的代碼抽取,可以看控制臺(tái)的network里各個(gè)js文件的大小,并且可以打開(kāi)看看里面的內(nèi)容,尋找你的優(yōu)化點(diǎn)~
這是我項(xiàng)目的優(yōu)化過(guò)程,大都只講思路,沒(méi)有涉及很具體,可能還有些缺陷和錯(cuò)誤,歡迎批評(píng)指教,一起交流學(xué)習(xí)。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/93699.html
摘要:一前言提綱基于和框架寫(xiě)的一個(gè)全棧購(gòu)物商城,記錄項(xiàng)目過(guò)程中遇到的一些問(wèn)題以及經(jīng)驗(yàn)和技巧。服務(wù)端技術(shù)棧登錄授權(quán)用認(rèn)證機(jī)制,來(lái)實(shí)現(xiàn)登錄登出。服務(wù)器配置和緩存策略,根據(jù)不同的來(lái)代理。申請(qǐng)證書(shū)全站升級(jí)到,配置的協(xié)議。一、前言提綱 基于Vue和Express框架寫(xiě)的一個(gè)全棧購(gòu)物商城,記錄項(xiàng)目過(guò)程中遇到的一些問(wèn)題以及經(jīng)驗(yàn)和技巧。 二、歷史版本 基于Vue-CLI2.0:點(diǎn)我查看 這個(gè)分支版本是一兩年前...
摘要:一前言提綱基于和框架寫(xiě)的一個(gè)全棧購(gòu)物商城,記錄項(xiàng)目過(guò)程中遇到的一些問(wèn)題以及經(jīng)驗(yàn)和技巧。服務(wù)端技術(shù)棧登錄授權(quán)用認(rèn)證機(jī)制,來(lái)實(shí)現(xiàn)登錄登出。服務(wù)器配置和緩存策略,根據(jù)不同的來(lái)代理。申請(qǐng)證書(shū)全站升級(jí)到,配置的協(xié)議。 一、前言提綱 基于Vue和Express框架寫(xiě)的一個(gè)全棧購(gòu)物商城,記錄項(xiàng)目過(guò)程中遇到的一些問(wèn)題以及經(jīng)驗(yàn)和技巧。 二、歷史版本 基于Vue-CLI2.0:點(diǎn)我查看這個(gè)分支版本是一兩...
摘要:以為例,編寫(xiě)來(lái)幫助我們完成重復(fù)的工作編譯壓縮我只要執(zhí)行一下就可以檢測(cè)到文件的變化,然后為你執(zhí)行一系列的自動(dòng)化操作,同樣的操作也發(fā)生在這些的預(yù)處理器上。的使用是針對(duì)第三方類(lèi)庫(kù)使用各種模塊化寫(xiě)法以及語(yǔ)法。 showImg(https://segmentfault.com/img/bVbtZYK); 一:前端工程化的發(fā)展 很久以前,互聯(lián)網(wǎng)行業(yè)有個(gè)職位叫做 軟件開(kāi)發(fā)工程師 在那個(gè)時(shí)代,大家可能...
摘要:前言是現(xiàn)階段很流行的前端框架,很多人通過(guò)官方文檔的學(xué)習(xí),對(duì)的使用都有了一定的了解,但再在項(xiàng)目工程化處理的時(shí)候,卻發(fā)現(xiàn)不知道改怎么更好的管理自己的項(xiàng)目,如何去引入一些框架以及全家桶其他框架的使用,以下將詳細(xì)地介紹本人在處理工程文件構(gòu)建的過(guò)程對(duì) 前言 vue是現(xiàn)階段很流行的前端框架,很多人通過(guò)vue官方文檔的學(xué)習(xí),對(duì)vue的使用都有了一定的了解,但再在項(xiàng)目工程化處理的時(shí)候,卻發(fā)現(xiàn)不知道改怎...
摘要:前言是現(xiàn)階段很流行的前端框架,很多人通過(guò)官方文檔的學(xué)習(xí),對(duì)的使用都有了一定的了解,但再在項(xiàng)目工程化處理的時(shí)候,卻發(fā)現(xiàn)不知道改怎么更好的管理自己的項(xiàng)目,如何去引入一些框架以及全家桶其他框架的使用,以下將詳細(xì)地介紹本人在處理工程文件構(gòu)建的過(guò)程對(duì) 前言 vue是現(xiàn)階段很流行的前端框架,很多人通過(guò)vue官方文檔的學(xué)習(xí),對(duì)vue的使用都有了一定的了解,但再在項(xiàng)目工程化處理的時(shí)候,卻發(fā)現(xiàn)不知道改怎...
閱讀 2611·2021-10-14 09:43
閱讀 3570·2021-10-13 09:39
閱讀 3304·2019-08-30 15:44
閱讀 3154·2019-08-29 16:37
閱讀 3718·2019-08-29 13:17
閱讀 2742·2019-08-26 13:57
閱讀 1834·2019-08-26 11:59
閱讀 1261·2019-08-26 11:46