這篇文章主要介紹如何打包優化Angular6項目,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
創新互聯公司公司2013年成立,先為臨高等服務建站,臨高等地企業,進行企業商務咨詢服務。為臨高企業網站制作PC+手機+微官網三網同步一站式服務解決您的所有建站問題。可以從以下三個角度優化:
輸出包體組成分析文件
Rollup 搖樹優化
導出Webpack配置,通過修改webpack配置優化打包
讓我們來逐一分析。
輸出包體組成分析文件
Webpack 有一個非常好用的工具叫 webpack-bundle-analyzer,會自動分析包體組成結構,并以一種可視化的方式顯示。
使用步驟:
打開項目,命令行輸入:npm install webpack-bundle-analyzer --save-dev
命令行輸入項目打包命令加--stats-json
在package.json文件的"scripts"里配置里,添加"bundle-report": "webpack-bundle-analyzer dist/wp/stats.json"
命令行輸入:npm run bundle-report
瀏覽器輸入:http://127.0.0.1:8888/ 查看分析圖,根據分析圖了解一些優化的細節
備注:在不影響性能的情況下,盡量少用Base64引入圖片,把圖片放在本地引入,不會打包到項目中去,但使用Base64編碼的圖片,會以圖片的1.5倍體積打包到項目中去,且若該圖片為精靈圖,使用圖片時采取了div切圖,切了幾次,就會打包幾次,占用體積非常大。具體可以參考以下:https://www.imooc.com/article/27804
Rollup 搖樹優化
所謂Rollup是指Webpack2會把那些應用中未使用的引用代碼除掉,但不會刪除這些代碼,所以就需要配合 UglifyJs 能夠智能的
移除這些未使用的代碼。從而減少包體大小。
而Agnular應用是基于Typescript,因此Angular Cli提供了一個叫 Angular Build Optimizer 插件,將 Typescript 編譯結果轉化成更友好的UglifyJs版本。這樣UglifyJs就能夠更有效的移除那些未使用的代碼
方法一:Angular Cli只需要在打包命令中加上 --build-optimizer 參數就可以,在一些情況下壓縮的還是很厲害的(但我做優化的過程中,使用了這樣的方法,毫無作用)
方法二:去掉沒有用到的模塊,從而減小體積
1、moment
對于 ng-cli 的項目:
(1)運行npm uninstall moment
(2)運行npm install moment --save-dev
(3).angular-cli.json 文件的 scripts
里加上"../node_modules/moment/min/moment.min.js"
(4)typings.d.ts 文件的最后加上 declare var moment: any;
(5)將項目中的代碼 import * as moment from 'moment';
全部干掉
備注:如果想應用其中某個庫則需要(以 fr 為例)
引入:import "moment/locale/fr";
使用:moment.locale("fr");
對于 webpack 的項目:
(1)在 webpack 配置文件的 plugins 里加上
new webpack.ContextReplacementPlugin(/moment[\/\\]locale$/, / /)
或者
new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/)
備注:如果想應用其中某個庫則需要(以 de、fr、hu 為例),在 webpack 配置文件的 plugins 里加上new webpack.ContextReplacementPlugin(/moment[\/\\]locale$/, /de|fr|hu/)
2、@ng-bootstrap/ng-bootstrap
如果在項目中要用到 @ng-bootstrap/ng-bootstrap 庫,要注意一下使用方法,如果按照其官網示例方式引入的話,在打包的時候會把其下所有模塊引入進來,不管你用沒用到。所以要想辦法把沒有用到的模塊干掉,只引入需要的模塊。
以時間組件為例,官網示例:
// 根模塊 import {NgbModule} from '@ng-bootstrap/ng-bootstrap'; @NgModule({ declarations: [AppComponent, ...], imports: [NgbModule.forRoot(), ...], bootstrap: [AppComponent] }) export class AppModule { }
// 其他需要模塊 import {NgbModule} from '@ng-bootstrap/ng-bootstrap'; @NgModule({ declarations: [OtherComponent, ...], imports: [NgbModule, ...], }) export class OtherModule { }
更改為:
// 根模塊 import {NgbDatepickerModule, NgbTimepickerModule} from '@ng-bootstrap/ng-bootstrap'; @NgModule({ declarations: [AppComponent, ...], imports: [NgbDatepickerModule.forRoot(), NgbTimepickerModule.forRoot() ...], bootstrap: [AppComponent] }) export class AppModule { }
// 其他需要模塊 import {NgbDatepickerModule, NgbTimepickerModule} from '@ng-bootstrap/ng-bootstrap'; @NgModule({ declarations: [OtherComponent, ...], imports: [NgbDatepickerModule, NgbTimepickerModule, ...], }) export class OtherModule { }
導出Webpack配置
方法一:eject(Angular6可能不支持)
方法二:工具庫ngx-build-plus
我期望通過導出Webpack配置的方式,使scss文件與main.js打包分離,仍在實踐中,成功后續更。
以上是“如何打包優化Angular6項目”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯成都網站設計公司行業資訊頻道!
另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
網頁名稱:如何打包優化Angular6項目-創新互聯
網頁鏈接:http://vcdvsql.cn/article42/cdjgec.html
成都網站建設公司_創新互聯,為您提供軟件開發、云服務器、動態網站、網站策劃、定制開發、外貿網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯