自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何利用TypeScript提升JavaScript編程效果

譯文
移動開發(fā) Android
如果非要從現(xiàn)代開發(fā)領(lǐng)域找出一種通用語言的話,那么大多數(shù)人可能會把支持票投給JavaScript,網(wǎng)景公司打造的這款瀏覽器腳本語言在其近二十年的發(fā)展歷程當(dāng)中一直在不斷成長,而且如今幾乎滲透到了我們生活的方方面面。

TypeScript能夠幫助大家編寫出更出色的JavaScript代碼、搞定規(guī)??捎^的JavaScript項目并為ECMAScript 6的來臨做好準備——更重要的是,上手TypeScript幾乎沒有任何難度可言。

如果非要從現(xiàn)代開發(fā)領(lǐng)域找出一種通用語言的話,那么大多數(shù)人可能會把支持票投給JavaScript。網(wǎng)景公司打造的這款瀏覽器腳本語言在其近二十年的發(fā)展歷程當(dāng)中一直在不斷成長,而且如今幾乎滲透到了我們生活的方方面面。它不僅植根于開發(fā)工具的核心深處,同時也在Node.js等服務(wù)器端實現(xiàn)方案中有所體現(xiàn),甚至已經(jīng)作好了進軍微服務(wù)架構(gòu)的戰(zhàn)斗準備。JavaScript同時也是相當(dāng)一部分微軟開發(fā)技術(shù)方案的關(guān)鍵性組成部分。打算對微軟Office進行擴展?我們必須得使用JavaScript。想為Windows 10編寫一套用戶界面?JavaScript仍然是最好的選擇。

不過JavaScript本身還遠遠稱不上完美,特別是在大家希望構(gòu)建一款包含有大量客戶端代碼的大型Web應(yīng)用程序時。在這種情況下,TypeScript現(xiàn)身救駕了。TypeScript屬于JavaScript的一套超集,其中不僅加入了大量用于即將面世的ECMAScript 6的功能特性,同時也可以通過編譯將開發(fā)成果轉(zhuǎn)換為JavaScript代碼以供現(xiàn)代瀏覽器接納——當(dāng)然也包括Node.js。

TypeScript是由微軟公司下轄的技術(shù)團隊負責(zé)設(shè)計,負責(zé)人為Anders Hjelsberg(他最廣為人知的成果應(yīng)該是Turbo Pascal、Delphi以及C#)。微軟的這個專項團隊在設(shè)計過程中,將TypeScript打造成了一款能夠利用編譯器將所開發(fā)代碼轉(zhuǎn)換為JavaScript形式的方案。大家只需在TypeScript當(dāng)中編寫代碼,而后將其交付至編譯器即可。由此生成的JavaScript轉(zhuǎn)換結(jié)果既能夠運行在服務(wù)器端,又可以由客戶端中的HTML進行調(diào)用。

TypeScript還將大量ECMAScript 6功能加入到了JavaScript當(dāng)中,具體包括類與模塊。此外,該團隊還嘗試將這兩種本是同根生的語言加以進一步融合,從而滿足ECMAScript 6的標準化方法要求。這絕對是個明智的決定。通過這種方式,大家可以利用TypeScript開發(fā)出能夠為ECMAScript 6所接納的代碼,同時充分發(fā)揮TypeScript的靜態(tài)類型優(yōu)勢以提升代碼安全性水平。

如果大家此前曾經(jīng)使用過C或者Fortran等語言,那么一定不會對靜態(tài)類型感到陌生——它允許我們面向變量進行類型聲明,從而確保A始終屬于整數(shù)而C始終屬于字符串。雖然TyperScript的類型安全性并不像Fortran那么全面,但其仍然能夠定義數(shù)字與字符串,并利用Boolean類型顯著改善代碼調(diào)試機制。除此之外,TyperScript還提供選項以實現(xiàn)類型推斷,從而降低發(fā)生錯誤的可能性——例如我們可能會把某個對象分配給未經(jīng)過適當(dāng)轉(zhuǎn)換的字符串。如果大家的代碼為兩個數(shù)字相加,那么TyperScript會認定其結(jié)果始終為數(shù)字。

大家也可以利用TypeScript將類型應(yīng)用至數(shù)組當(dāng)中,或者利用enums為特定變量名稱設(shè)置值。作為一款極具實用性的工具,enums具備雙向?qū)傩?,因此大家可以利用它通過數(shù)字來查找某條變量名稱——這就使得大家可以在代碼當(dāng)中更輕松地建立鍵/值記錄。如果大家不確定自己可能使用哪種類型,則可以將變量設(shè)定為any,在這種情況下TypeScript不會推斷其具體類型、大家也不會因此遇到錯誤或者警告。TypeScript類型可以自行選擇,因此我們用不著在編譯或者運行之前、首先向現(xiàn)有代碼添加各種類型,而這將有效簡化現(xiàn)有代碼的相關(guān)遷移工作。再有,我們可以從純JavaScript代碼入手,而后隨著其它TypeScript功能的加入而同時添加相關(guān)類型。

需要注意的是,大家的現(xiàn)有JavaScript代碼將成為TypeScript應(yīng)用程序的一部分加以運行。而如果將代碼遷移到ECMAScript 6或者TypeScript語法形式下,大家即可享受到TypeScript的各種功能優(yōu)勢。而如果我們使用具備TypeScript識別能力的工具,則可以擁有面向Visual Studio IntelliSense的支持能力——其能夠幫助我們對函數(shù)調(diào)用中的類型進行管理。除此之外,大家也能夠利用TypeScript聲明文件向各類常用庫及服務(wù)中快速添加類型支持,例如人氣極高的jQuery庫。

擁有這樣一款類型化且近似于JavaScript的語言能夠給類使用與模塊構(gòu)建帶來顯著簡化(與AngularJS當(dāng)中的處理方式非常相近)。類型的存在能夠確保某個警告類中的所有實例都通過字符串進行調(diào)用,這將幫助我們輕松構(gòu)建起更理想的構(gòu)造函數(shù)。大家可以將這種類型化構(gòu)造函數(shù)調(diào)用視為一種契約,負責(zé)定義兩段代碼之間的相互作用——并幫助我們更輕松地在不同應(yīng)用程序之間重復(fù)使用同一函數(shù)。

在函數(shù)調(diào)用當(dāng)中定義類型正是創(chuàng)建接口結(jié)構(gòu)的關(guān)鍵所在,能夠使我們的代碼更具面向?qū)ο筇匦?。大家可以將函?shù)元素明確定義為接口,并選擇在函數(shù)當(dāng)中使用更具描述性的名稱,同時又不會影響到進行調(diào)用檢查時向IntelliSense等函數(shù)所必需的工具發(fā)出通知。

以這種方式定義類型與接口,能夠讓多位開發(fā)人員輕松對大型JavaScript項目加以管理。而在函數(shù)與類設(shè)計中秉持“接口至上”的契約化方法,則能夠幫助大家在對應(yīng)用程序中特定部分進行優(yōu)化時不至于影響到其余部分,或者從其他開發(fā)者手中借用某種接口定義并直接運用到其它實現(xiàn)方案當(dāng)中。這種方式允許我們以更為高效的方式使用諸如Git以及GitHub等工具,從而在一套持續(xù)開發(fā)模型當(dāng)中輕松管理多個代碼分支。

如果大家使用的是Java或者C#語言,那么對TypeScript(以及ECMAScript 6)的類實現(xiàn)機制一定不會感到陌生。大家可以在構(gòu)造函數(shù)之內(nèi)創(chuàng)建類,從而對方法中所使用的類型進行定義,最終利用類似的來處理各種內(nèi)部對象。大家也可以利用繼承、添加功能與重寫方法等方式對類進行擴展。而更值得注意的是,TypeScript還支持常見于函數(shù)與接口當(dāng)中的泛型——其能夠幫助大家交付可重復(fù)使用的函數(shù)。

一旦掌握了TypeScript處理類與函數(shù)的方式,大家就可以著手將其組織在模塊當(dāng)中,在這里類與函數(shù)能夠被拆分至多個文件當(dāng)中。這顯然是一種非常便捷的代碼組織方案——舉例來說,我們可以利用幾個文件來處理購物車當(dāng)中的不同函數(shù)。在此之后,大家可以對各個子模塊進行分別更新,從而在特定函數(shù)中利用調(diào)整歸零機制改善其性能水平,同時又不至于對其它函數(shù)造成影響。具備聲明文件的JavaScript庫也可以作為模塊使用,因此大家能夠在TypeScript應(yīng)用程序當(dāng)中充分發(fā)揮由此帶來的諸多優(yōu)勢。

如果大家希望利用TypeScript處理日常開發(fā)工作,那么當(dāng)前版本的Visual Studio以及新的Visual Studio Code跨平臺編輯工具都提供相關(guān)支持能力。除此之外,TypeScript網(wǎng)站上還擁有一套在線編碼環(huán)境,大家可以點擊此處訪問并在這里體驗自己的編碼思路或者查看在線教程。

在將JavaScript引入大型乃至超大型項目當(dāng)中時,以TypeScript作為切入點能夠帶來極為可觀的現(xiàn)實意義。TypeScript不僅能夠幫助大家在具備充分掌控能力且遵循可重復(fù)使用方針的前提下完成編碼工作,同時也能夠擁有一條通往ECMAScript 6的理想路徑。

責(zé)任編輯:chenqingxiang 來源: 51CTO
相關(guān)推薦

2025-04-07 04:00:00

AngularTypeScript裝飾器

2021-01-12 10:22:45

JavaScript并發(fā)控制前端

2015-07-24 19:10:47

大數(shù)據(jù)

2023-06-07 09:00:00

JavaScript開發(fā)TypeScript

2024-06-28 16:15:59

CIO銷售漏斗

2025-02-25 11:12:53

2011-08-09 17:15:45

注冊表注冊表編輯器

2020-04-17 10:14:47

人工智能AI客戶服務(wù)

2010-11-18 23:39:48

云計算

2016-10-27 08:39:35

大數(shù)據(jù)設(shè)計定量

2018-01-10 15:03:27

前端TypeScriptJavaScript

2012-10-08 09:15:57

JavaScriptJSTypeScript

2019-08-30 08:54:05

TypeScriptJavaScript語言

2010-07-30 13:08:38

Flex調(diào)用JavaS

2022-05-30 14:33:55

MLOpsIDC人工智能

2021-04-24 23:31:18

Python日志編程

2023-12-01 07:10:01

JavascriptTypescript

2011-09-15 17:49:32

Windows7效率

2016-01-29 10:39:35

排序搜索美團

2009-06-18 12:21:07

javascriptdom
點贊
收藏

51CTO技術(shù)棧公眾號