亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解angularjs4部署文件過大解決過程

 更新時(shí)間:2018年12月05日 10:34:52   作者:涼瓜皮  
這篇文章主要介紹了詳解angularjs4部署文件過大解決過程,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

這是我人生的第一篇文章,寫得不好,請(qǐng)見諒!

本人是一個(gè)java web開發(fā)工程師,對(duì)angularjs4小有接觸,最近看到一個(gè)漂亮的angularjs4的后臺(tái)模板–angle,于是就在CSDN下載來測(cè)試一下,點(diǎn)擊這里下載

模板的一些照片

 

相信有經(jīng)驗(yàn)的都知道,要運(yùn)行先安裝nodejs,配置nodejs環(huán)境等等,這里就不細(xì)說了,網(wǎng)上有很多這樣的文章,而我參考的文章是,點(diǎn)擊這里

所有東西都搞掂了,然后就是打包部署,放在服務(wù)器玩玩了, 

下面就是我遇到的問題和解決辦法:

1、ng build 打包,加載的js文件高達(dá)8.6M

ng build

在本地nginx或者tomcat直接運(yùn)行,感覺還不錯(cuò),還以為就這么的搞掂了,真的很開心!直接就把它用winFcp復(fù)制到自己阿里云上,打開主頁,瞬間懵逼了。好慢好慢,等了2分多鐘才打開了這個(gè)頁面。

 

肯定我這里出問題,因?yàn)槲疑蟖ngle頁面demo是這樣子,看下面的圖

 

于是我百度了一下,發(fā)現(xiàn)ng build是有模式選擇的,打包是用生產(chǎn)模式(–prod)

2、ng build –prod打包,這次優(yōu)了點(diǎn)js 4.1M

ng build --prod
ng build --prod --aot

這兩個(gè)代碼是一樣,我也不知道開始–prod就默認(rèn)開啟aot了

這里,–prod參數(shù)后,angular-cli會(huì)把用不到的包都刪掉,而–aot參數(shù)是讓angular-cli啟動(dòng)預(yù)編譯特性

在命令行中輸入這個(gè)代碼,出現(xiàn)了問題了,報(bào)錯(cuò):Module not found: Error: Can't resolve ‘./$$_gendir/app/app.module.ngfactory'

很多我找了到問題的解決辦法

是因?yàn)閍ngular-cli 的版本有點(diǎn)低了,通過下面的代碼來升到最新的版本

npm install --save-dev @angular/cli@latest

終于可以,看看效果如何,
 ‘

 

少是少了很多,但遠(yuǎn)遠(yuǎn)不夠,問題出在哪呢?

能有什么辦法?也只能繼續(xù)百度了,我發(fā)現(xiàn)了ng serve這段代碼,ng serve是啟動(dòng)一個(gè)小型web服務(wù)器,用于托管應(yīng)用。

ng serve --prod --aot

驚奇發(fā)現(xiàn),js文件只有1.1M比官網(wǎng)略優(yōu)啊

 

那疑問就來了,難道我要在服務(wù)器上架開發(fā)環(huán)境,好像不太現(xiàn)實(shí)吧。

3、nginx開啟gzip優(yōu)化,這次js是1.2M

又開始了我的百度之旅,我發(fā)現(xiàn)了一個(gè)東西 — gzip,是在nginx上開啟gzip,優(yōu)化訪問速度

于是,我就在nginx上加了這段代碼

gzip on;
gzip_min_length 1k;
gzip_buffers 4 16k;
gzip_comp_level 2;
gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;
gzip_vary on;
gzip_disable "MSIE [1-6]\.";

文章中沒說這段東西放在哪,這里說以下,放在server括號(hào)里面就可以了。

最后的結(jié)果,如下

 

但是,這好像和官網(wǎng)的demo還是有點(diǎn)差距啊,可能改以下gzip會(huì)有更好的效果,同時(shí)我還發(fā)現(xiàn)了一個(gè)問題,這個(gè)模板是把所有的東西都加載完才打開頁面,其實(shí)有的東西是可以后面再加載的,所以接下來我就要在模板自身來優(yōu)化了。

等我找到更好的優(yōu)化方法會(huì)及時(shí)更新,謝謝大家,如有錯(cuò)誤,請(qǐng)指出

2017年9月15日晚上更新

在上個(gè)星期,我已經(jīng)優(yōu)化了不少了,

 

 

自從上次寫完這貼后,我就繼續(xù)上網(wǎng)搜一下優(yōu)化方法,我找到一天文章說,先gzip壓縮到,然后再上傳到服務(wù)器會(huì)快很多,我嘗試過,并沒有得到這樣的結(jié)論,在nginx上是可以開啟緩存的功能的,它把項(xiàng)目gzip壓縮后,然后緩存在服務(wù)器上,每次打開網(wǎng)站時(shí),取的是gzip后的文件,說明你壓縮再上傳和上傳后再配置壓縮是一樣的,并沒有得到優(yōu)化。
有VPN的我,轉(zhuǎn)戰(zhàn)了google,

我找到了一個(gè)比我還努力的哥們,地址

這位哥們從7.07s優(yōu)化到732ms,從4.5M優(yōu)化到317.5kb全過程,測(cè)試網(wǎng)址是點(diǎn)擊跳轉(zhuǎn)

其中有的是重復(fù)了,有的是不錯(cuò)的做法,如下

(1)實(shí)現(xiàn)緩存,實(shí)際操作過程,是在nginx中server上,添加了這段東西

location ~* \.(gif|jpe?g|png|ico|swf)$ {
 # d - 天
 # h - 小時(shí)
 # m - 分鐘
 expires 168h;
 add_header Pragma public;
 add_header Cache-Control "public, must-revalidate, proxy-revalidate";
 }

 # 由于js和css文件需要改動(dòng),設(shè)置的時(shí)間為5分鐘
 location ~* \.(css|js)$ {
   expires 5m;
   add_header Pragma public;
   add_header Cache-Control "public, must-revalidate, proxy-revalidate";
 }

(2)更改了gzip壓縮參數(shù),地址(可能是官網(wǎng)吧,反正做得很漂亮),gzip的壓縮變成如下

gzip on;
 gzip_static on;
 gzip_comp_level 2;
 gzip_http_version 1.0;
 gzip_proxied any;
 gzip_min_length 1100;
 gzip_buffers 16 8k;
 gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;

 # Disable for IE < 6 because there are some known problems
 gzip_disable "MSIE [1-6].(?!.*SV1)";

 # Add a vary header for downstream proxies to avoid sending cached gzipped files to IE6
 gzip_vary on;

(3)我發(fā)現(xiàn)項(xiàng)目打包的時(shí)候出錯(cuò)了,我把–AOT打成-AOT,一個(gè)一個(gè)符號(hào)只差就使得script.js這個(gè)文件少了一半

現(xiàn)在這次網(wǎng)頁優(yōu)化得比官網(wǎng)的還好了,如果還要弄的話,剩下的應(yīng)該是減少了一下項(xiàng)目中沒用的公共模塊,可能又可以 減少一半,那就非常滿意了,這個(gè)帖子算是終結(jié)了,主要是介紹了一下,我部署的全過程。

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

相關(guān)文章

  • 使用RxJS更優(yōu)雅地進(jìn)行定時(shí)請(qǐng)求詳析

    使用RxJS更優(yōu)雅地進(jìn)行定時(shí)請(qǐng)求詳析

    這篇文章主要給大家介紹了關(guān)于如何使用RxJS更優(yōu)雅地進(jìn)行定時(shí)請(qǐng)求的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用RxJS具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 深入理解Angular中的依賴注入

    深入理解Angular中的依賴注入

    本篇文章主要介紹了深入理解Angular中的依賴注入,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • AngularJS控制器之間的數(shù)據(jù)共享及通信詳解

    AngularJS控制器之間的數(shù)據(jù)共享及通信詳解

    本文詳細(xì)介紹了AngularJS控制器之間的數(shù)據(jù)共享與通信,對(duì)angularjs共享數(shù)據(jù)及通信相關(guān)知識(shí)感興趣的朋友可以一起學(xué)習(xí)。
    2016-08-08
  • Angular實(shí)現(xiàn)下拉框模糊查詢功能示例

    Angular實(shí)現(xiàn)下拉框模糊查詢功能示例

    這篇文章主要介紹了Angular實(shí)現(xiàn)下拉框模糊查詢功能,涉及AngularJS事件響應(yīng)及字符串查詢等相關(guān)操作技巧,需要的朋友可以參考下
    2018-01-01
  • AngularJs Understanding the Controller Component

    AngularJs Understanding the Controller Component

    本文主要介紹AngularJs Understanding the Controller Component的內(nèi)容,這里整理了相關(guān)資料,及簡單示例代碼,有興趣的小伙伴可以參考下
    2016-09-09
  • AngularJS基礎(chǔ) ng-keyup 指令簡單示例

    AngularJS基礎(chǔ) ng-keyup 指令簡單示例

    本文主要介紹AngularJS ng-keyup 指令,這里對(duì)ng-keyup指令的基本資料進(jìn)行了整理,并且附有代碼示例,有需要的朋友可以看一下
    2016-08-08
  • 詳解Angular組件生命周期(一)

    詳解Angular組件生命周期(一)

    每個(gè)Angular版本在其生命周期中都經(jīng)歷了各個(gè)階段。組件在Angular中起著關(guān)鍵作用; 在這里,本文將討論Angular中的組件生命周期以及它們?nèi)绾斡绊懣蚣芩邪姹镜纳芷凇?/div> 2021-05-05
  • ANGULARJS中使用JQUERY分頁控件

    ANGULARJS中使用JQUERY分頁控件

    本文給大家介紹ANGULARJS中使用JQUERY分頁控件,需要的朋友可以參考下
    2015-09-09
  • Angular4實(shí)現(xiàn)圖片上傳預(yù)覽路徑不安全的問題解決

    Angular4實(shí)現(xiàn)圖片上傳預(yù)覽路徑不安全的問題解決

    這篇文章主要給大家介紹了關(guān)于Angular4實(shí)現(xiàn)圖片上傳預(yù)覽路徑不安全問題的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-12-12
  • Angular實(shí)現(xiàn)點(diǎn)擊按鈕后在上方顯示輸入內(nèi)容的方法

    Angular實(shí)現(xiàn)點(diǎn)擊按鈕后在上方顯示輸入內(nèi)容的方法

    這篇文章主要介紹了Angular實(shí)現(xiàn)點(diǎn)擊按鈕后在上方顯示輸入內(nèi)容的方法,涉及AngularJS事件響應(yīng)及頁面元素屬性動(dòng)態(tài)設(shè)置相關(guān)操作技巧,需要的朋友可以參考下
    2017-12-12

最新評(píng)論