摘要:在整篇文章中,我將解釋如何使用以及為什么去使用。如果沒有,這兩個錯誤將被忽視,導(dǎo)致最終應(yīng)用程序出現(xiàn)一些錯誤。我們可以在從其他文件導(dǎo)入的類中使用自動完成功能。維護(hù)的難度是和開發(fā)人員避免將大型項目遷移到的主要原因之一。
在我的職業(yè)生涯開始時,我是一名桌面應(yīng)用開發(fā)人員,其中強(qiáng)類型語言占據(jù)了市場主導(dǎo)地位。
當(dāng)我遷移到Web開發(fā)時,我對JavaScript和Python等語言的每個新功能都很著迷。事實上,我沒有必要聲明變量的類型,這極大的提高了我的生產(chǎn)力,并且使我的工作變得更有趣了。
所以我第一次聽說TypeScript時,腦海中的第一個想法是這個語言的演變是不是倒退了一步。
是的,但這也要取決于具體情況。對于我獨(dú)自工作的個人項目,我仍然更喜歡純JavaScript,他的生產(chǎn)力更高。但是,對于那種團(tuán)隊工作的大型項目,我建議使用TypeScript。在整篇文章中,我將解釋如何使用以及為什么去使用。
生產(chǎn)力與維護(hù)根據(jù)概念定義的,“TypeScript是用于應(yīng)用程序規(guī)模開發(fā)的JavaScript”。也就是說,我們對項目初始設(shè)置的工作可以通過復(fù)雜項目的可維護(hù)性得到補(bǔ)償。下面我們來看一下為什么會發(fā)生這種情況:
輸入safe = less errors通過在代碼中定義類型,您可以允許IDE在使用僅在運(yùn)行時感知的類和函數(shù)時確認(rèn)錯誤。
例:
這里我使用的是Visual Studio Code,它指出了兩個錯誤:
在第6行:我們試圖將字符串參數(shù)傳遞給只接受數(shù)字的函數(shù)。
在第9行:我們試圖將一個返回數(shù)字的函數(shù)的結(jié)果賦給字符串。
如果沒有Typescript,這兩個錯誤將被忽視,導(dǎo)致最終應(yīng)用程序出現(xiàn)一些錯誤。
在復(fù)雜的項目中,我們有數(shù)百個類分布在多個文件中。當(dāng)我們定義類型時,IDE能夠?qū)ο蠛秃瘮?shù)關(guān)聯(lián)到給它們起源的文件。
當(dāng)使用control + 單擊從另一個文件導(dǎo)入的方法或類時,IDE將自動導(dǎo)航到導(dǎo)入的文件,突出顯示定義引用的行。
我們可以在從其他文件導(dǎo)入的類中使用自動完成功能。
維護(hù)的難度是Java和C#開發(fā)人員避免將大型項目遷移到JS的主要原因之一。我們可以說,Typescript是一種克服這一障礙的企業(yè)語言。
如何使用Typescript設(shè)置Express項目現(xiàn)在讓我們一步一步地創(chuàng)建一個在Express.js項目中使用Typescript語言的環(huán)境。
npm init
我們現(xiàn)在安裝typescript包。
npm安裝typescript -s
關(guān)于Typescript節(jié)點包
Node.js是一個運(yùn)行Javascript而不是Typescript的引擎。節(jié)點Typescript包允許您將 .ts文件轉(zhuǎn)換為 .js腳本。Babel也可用于轉(zhuǎn)換Typescript,但市場標(biāo)準(zhǔn)是使用官方的Microsoft軟件包。
在我們內(nèi)部package.json我們將放置一個名為tsc:
“scripts”:{ “tsc”:“tsc” },
此修改允許我們從項目文件夾中的命令行調(diào)用typescript函數(shù)。所以我們可以使用以下命令:
npm run tsc - --init
此命令通過創(chuàng)建tsconfig.json文件來初始化typescript項目。在此文件中,我們將取消注釋該outDir選項,并為要傳遞的已轉(zhuǎn)換的.js文件選擇一個位置:
安裝express.jsnpm install express -s
Express和Typescript包是獨(dú)立的。這樣做的結(jié)果是Typescript不“知道”Express類的類型。Typescript有一個特定的npm包來識別Express類型。
npm install @ types / express -sHello world
為了擁有盡可能最簡單的應(yīng)用程序,我將使用express.js教程的hello world示例:
var express = require("express"); var app = express(); app.get("/", function (req, res){ res.send("hello world!"); }); app.listen(3000, function(){ console.log("Example app listening on port 3000"); })
在我們的項目中,我們將創(chuàng)建一個名為的文件夾app。在此文件夾中,我們將創(chuàng)建一個名為app.ts以下內(nèi)容的文件:
import express = require("express"); // Create a new express application instance const app: express.Application = express(); app.get("/", function (req, res) { res.send("Hello World!"); }); app.listen(3000, function () { console.log("Example app listening on port 3000!"); });編譯我們的第一個應(yīng)用程序
npm run tsc
如您所見,該命令自動創(chuàng)建了build文件夾和.js文件。
運(yùn)行express:node build / app.js
有了這個,我們已經(jīng)在端口3000上運(yùn)行了一個服務(wù)器:
運(yùn)行TypeScript而不進(jìn)行轉(zhuǎn)換您可以使用ts-node包直接在節(jié)點上運(yùn)行typescript 。
此軟件包僅建議用于開發(fā)。要在生產(chǎn)中進(jìn)行最終部署,請始終使用項目的javascript版本。
該ts-node已被包含在另一個包的依賴關(guān)系,T ts-node-dev。安裝后,ts-node-dev我們可以運(yùn)行命令,以便在項目文件發(fā)生更改時重新啟動服務(wù)器。
npm安裝ts-node-dev -s
在我們內(nèi)部,packege.json我們將添加兩個腳本:
“scripts”:{ “tsc”:“tsc”, “dev”:“ts-node-dev --respawn --transpileOnly ./app/app.ts”,“prod”:“tsc && node ./build/ app.js“ },
要啟動開發(fā)環(huán)境:
npm run dev
要以生產(chǎn)模式運(yùn)行服務(wù)器:
npm run prod
有啥問題可以在評論處給我留言謝謝你的閱讀!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/108709.html
摘要:前言講起前端,我們就不能不講與,在這兩種技術(shù)廣泛應(yīng)用的今天,他們的擴(kuò)展也是層出不窮,的擴(kuò)展有等,的超集有等。如下注意你的樣式文件一定要在引入前先引入。截止目前,已經(jīng)發(fā)布了最新的版本。 前言:講起前端,我們就不能不講CSS與Javascript,在這兩種技術(shù)廣泛應(yīng)用的今天,他們的擴(kuò)展也是層出不窮,css的擴(kuò)展有Less、Sass、Stylus等,js的超集有Typescript等。今天我們就簡...
摘要:為目前使用范圍最廣的網(wǎng)絡(luò)保護(hù)協(xié)議。身處攻擊目標(biāo)周邊的惡意人士能夠利用密鑰重裝攻擊,利用此類安全漏洞。本文和大家一起探討下如何在三年內(nèi)快速成長為一名技術(shù)專家。 業(yè)界動態(tài) Vue 2.5 released Vue 2.5 正式發(fā)布,作者對于該版本的優(yōu)化總結(jié):更好的TypeScript 集成,更好的錯誤處理,更好的單文件功能組件支持以及更好的與環(huán)境無關(guān)的SSR WiFi爆驚天漏洞!KRACK...
摘要:談到函數(shù)式編程時,我們常提到機(jī)制方法,而不是核心原則。函數(shù)式編程不是關(guān)于和這些概念的,雖然它們確實很有用。從根本上來說,函數(shù)式編程就是關(guān)于如使用通用的可復(fù)用函數(shù)進(jìn)行組合編程。我們一起用一些函數(shù)式編程的辦法重構(gòu)這個函數(shù)吧。 原文作者:@VictorSavkin原文地址:https://vsavkin.com/functiona...中文翻譯:文藺譯文地址:http://www.wemli...
摘要:具體來說,包管理器就是可以通過命令行,幫助你把外部庫和插件放到你的項目里面并在之后進(jìn)行版本升級,這樣就不用手工復(fù)制和更新庫?,F(xiàn)在有的包管理器主要是和。 一、基礎(chǔ) 1、學(xué)習(xí)HTML基礎(chǔ) HTML給你的網(wǎng)頁賦予了結(jié)構(gòu)。它就像是人的骨架那樣讓你保持站立。首先你需要去學(xué)習(xí)語法以及它必須提供的一切。你的學(xué)習(xí)應(yīng)該聚焦在下面這些東西上: 學(xué)習(xí)HTML基礎(chǔ),了解如何編寫語義HTML 理解如何把網(wǎng)頁分...
閱讀 1351·2023-04-25 23:47
閱讀 929·2021-11-23 09:51
閱讀 4480·2021-09-26 10:17
閱讀 3729·2021-09-10 11:19
閱讀 3268·2021-09-06 15:10
閱讀 3556·2019-08-30 12:49
閱讀 2436·2019-08-29 13:20
閱讀 1743·2019-08-28 18:14