Angular5.0.0新特性
文章來自官網(wǎng)部分翻譯
https://blog.angular.io/version-5-0-0-of-angular-now-available-37e414935ced
Angular5.0.0版本已經(jīng)正式發(fā)布
總結(jié)一下v5.0.0帶來的新變化都有哪些。
1.構(gòu)建優(yōu)化
5.0版本默認(rèn)采用CLI構(gòu)建和打包。構(gòu)建優(yōu)化器是包含在CLI里面的一個(gè)工具,通過對你的應(yīng)用程序更加語義化的理解可以使得你的打包程序(bundle)更小。
構(gòu)建優(yōu)化器有兩個(gè)主要工作。
第一,我們可以將應(yīng)用程序的一部分標(biāo)記為純應(yīng)用(pure),改進(jìn)了現(xiàn)有工具提供的搖樹優(yōu)化,刪除了應(yīng)用中其它不需要的部分。
第二,從你的應(yīng)用程序在運(yùn)行時(shí)刪除裝飾符代碼(decorators),裝飾(decorators)是由編譯器使用的,而在運(yùn)行時(shí)并不需要可以被刪除。這些工作減少了生成的JavaScript bundles的大小,并增加了你的用戶應(yīng)用程序的啟動速度。
2.服務(wù)端狀態(tài)轉(zhuǎn)換和DOM支持
有了這個(gè)支持,可以讓應(yīng)用程序在服務(wù)器端和客戶端版之間共享狀態(tài)更容易。
Angular Universal是一個(gè)幫助開發(fā)者實(shí)現(xiàn)SSR的開源項(xiàng)目,通過在服務(wù)端渲染
Angular應(yīng)用程序,然后在客戶端引導(dǎo)啟動程序并生成HTML,由此更好的支持那些對javascript不太友好的化境來提高應(yīng)用程序性能。
5.0版本中,Angular開發(fā)團(tuán)隊(duì)添加了ServerTransferStateModule(與之對應(yīng)的BrowserTransferStateModule),這個(gè)模塊允許你在服務(wù)端生成模塊信息并傳輸?shù)娇蛻舳?,不需要在客戶端重?fù)創(chuàng)建。這一點(diǎn)在通過HTTP獲取數(shù)據(jù)并展示時(shí)非常有用。通過服務(wù)端狀態(tài)轉(zhuǎn)移,客戶端不需要在發(fā)送第二個(gè)HTTP數(shù)據(jù)請求,狀態(tài)轉(zhuǎn)移的API文檔將在未來幾周內(nèi)發(fā)布。
此處另一個(gè)改變是AngularUniversal團(tuán)隊(duì)添加了Domino渲染工具,Domino的加入意味著我們在服務(wù)器端上下文中將可以支持更多的DOM操作,改進(jìn)了對第三方JS和組件庫的支持。
3.編譯器改進(jìn)
改進(jìn)了Angular編譯器來支持增量編譯,重新構(gòu)建變得更快,特別是對生產(chǎn)環(huán)境的構(gòu)建和AOT編譯,增強(qiáng)的裝飾器可以通過更精細(xì)化的去除空格來減小產(chǎn)生的包.
改進(jìn)后的AOT編譯的性能大幅度,提升可以節(jié)省約95%的構(gòu)建時(shí)間,40s可以提升至2s完成一次構(gòu)建。
Preserve Whitespace
通過編譯器,模板開發(fā)中的制表符、換行符、空格等可以原樣的保留下來,并提供選項(xiàng)可以自選是否使用Preserve Whitespace來保留這些東西。
也可以在tsconfig.json設(shè)置作用到全局
注:組件級別的選項(xiàng)會覆蓋應(yīng)用程序級別的設(shè)置。
增強(qiáng)的裝飾符支持
裝飾符降低了在使用useValue、useFactory、data對lambda表達(dá)式的要求,開發(fā)者也可以使用一個(gè)lamdba表示來代替一個(gè)已定義的命名函數(shù),也就意味著你可以不事先在*.d.ts中聲明而直接執(zhí)行代碼。
去掉表達(dá)式方式
4.國際化號碼、日期和貨幣管道
Angular5中已經(jīng)建立了新的號碼,日期和貨幣管道,增加了跨瀏覽器的標(biāo)準(zhǔn)化實(shí)現(xiàn),消除國際化在不同環(huán)境中的差異。
在5.0中管道可以使用我們自己的實(shí)現(xiàn),可以在任何地方實(shí)現(xiàn)本地化的支持和配置。
V4 V5之間管道差異對比
https://docs.google.com/spreadsheets/d/12iygt-_cakNP1VO7MV9g4lq9NsxVWG4tSfc98HpHb0k/edit#gid=0
5.StaticInjector取代ReflectiveInjector依賴注入器
為了更多的減少polyfills,5.0中使用了StaticInjector注入器來替換原有的ReflectiveInjector注入器,這種注入器不再里來與ReflectPolyfill,可以大幅減少應(yīng)用程序體積
在4.x中,依賴注入器一共有兩種,即Injector的抽象類子類:
1._NullInjector (該類的實(shí)例用于表示空的注入器)
2.ReflectiveInjector (表示一個(gè)依賴注入容器,用于實(shí)例化對象和解析依賴)
之前提供依賴注入方式:ReflectiveInjector.resolveAndCreate(providers);5.0中方式:Injector.create(providers);
6.Zone執(zhí)行速度的提升
5.0中默認(rèn)提供的zones已經(jīng)優(yōu)化過,速度大幅提升,并且在應(yīng)用程序中繞過zonee區(qū)域更加關(guān)于應(yīng)用程序的性能。
繞過zone引導(dǎo)啟動應(yīng)用程序的方式:
platformBrowserDynamic().bootstrapModule(AppModule,{ngZone:'noop'}).then( ref => {} );
7.exportAs多命名支持
5.0中提供了組件/指令的多命名支持,在對用戶不修改代碼情況下進(jìn)行組件的遷移操作等非常有用,將一個(gè)組件導(dǎo)出多個(gè)名字,可以讓組件已一個(gè)新名字來使用而達(dá)到不破壞現(xiàn)有代碼的目的。
8.HttpClient
在4.3中HttpClient模塊被封裝在@angular/common中,新的HttpClient被封裝在@angular/common/http中,更新Http模塊后,需要使用HttpClientModule替換原有HttpModule,并在使用http服務(wù)時(shí),可以去掉map(res=>res.json())的調(diào)用,新模塊中已經(jīng)不再需要這么寫了。
9.CLI v1.5
Angular CLI v1.5版本中已經(jīng)添加了對5.0版本的支持,后期將會把v5.0.0作為CLI的默認(rèn)版本。這個(gè)版本中已經(jīng)默認(rèn)開啟了構(gòu)建優(yōu)化,所以開發(fā)者可以直接感受到更小的js打包優(yōu)化帶來的收益。同時(shí)也更新了.tsconfig將更嚴(yán)格的遵循TypeScript標(biāo)準(zhǔn),
10.Angular Forms adds updateOn Blur / Submit
可以使用blur/submit來進(jìn)行事件更新,而不用每個(gè)input都寫一個(gè)事件了。
Template Driven Forms Before <input name="firstName" ngModel> After <input name="firstName" ngModel [ngModelOptions]="{updateOn: 'blur'}"> or <form [ngFormOptions]="{updateOn: 'submit'}"> Reactive Forms Before new FormGroup(value); new FormControl(value, [], [myValidator]) After new FormGroup(value, {updateOn: 'blur'})); new FormControl(value, {updateOn: 'blur', asyncValidators: [myValidator]}) asyncValidators可以不再是作為一個(gè)參數(shù)傳遞 而是直接作用到表單上了。
11.RxJS 5.5
支持V5.2+ 5.5在bundle上更加優(yōu)化了
12.New Router Lifecycle Events
GuardsCheckStart
ChildActivationStart
ActivationStart
GuardsCheckEnd
ResolveStart
ResolveEnd
ActivationEnd
ChildActivationEnd
總結(jié)
以上所述是小編給大家介紹的Angular5.0.0新特性,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
解決android關(guān)于打開虛擬機(jī)時(shí)右側(cè)工具欄不顯示的問題
下面小編就為大家分享一篇解決android關(guān)于打開虛擬機(jī)時(shí)右側(cè)工具欄不顯示的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01android 6.0下webview的定位權(quán)限設(shè)置方法
今天小編就為大家分享一篇android 6.0下webview的定位權(quán)限設(shè)置方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07探討:android項(xiàng)目開發(fā) 統(tǒng)籌兼顧 需要考慮的因素
本篇文章是對基于android項(xiàng)目開發(fā) 統(tǒng)籌兼顧 需要考慮的因素進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06詳解Android開發(fā)之MP4文件轉(zhuǎn)GIF文件
這篇文章介紹的是將錄下來的視頻選取一小段轉(zhuǎn)為 GIF 文件,不僅時(shí)間段可以手動選取,而且還需要支持截取視頻的局部區(qū)域轉(zhuǎn)為 GIF,網(wǎng)上調(diào)研了一下技術(shù)方案,覺得還是有必要把實(shí)現(xiàn)過程拿出來分享下,有需要的可以直接拿過去用。下面來一起看看。2016-08-08Android使用popupWindow仿微信彈出框使用方法
這篇文章主要為大家詳細(xì)介紹了Android使用popupWindow仿微信彈出框使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-09-09基于Android自定義控件實(shí)現(xiàn)雷達(dá)效果
這篇文章主要為大家詳細(xì)介紹了基于Android自定義控件實(shí)現(xiàn)雷達(dá)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07Android編程中常用適配器及自定義適配器用法實(shí)例分析
這篇文章主要介紹了Android編程中常用適配器及自定義適配器用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了Android中適配器的概念、功能及自定義適配器的相關(guān)使用技巧,需要的朋友可以參考下2015-11-11AndroidStudio 3.6 中 R.layout 找不到對應(yīng)的xml文件問題及解決方法
這篇文章主要介紹了AndroidStudio 3.6 中 R.layout 找不到對應(yīng)的xml文件問題,本文給出了解決方法對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03