手把手教你使用TypeScript開發(fā)Node.js應(yīng)用
為什么要使用TypeScript?
為了減少代碼編寫過程中出現(xiàn)的錯誤,以及更好的維護(hù)你的項目,本文將手把手教你配置一個簡單的開發(fā)環(huán)境來編寫Node.js的應(yīng)用程序,創(chuàng)建這樣的一個開發(fā)環(huán)境有很多方式,這只是其中一種,希望對你有所幫助!
手把手教你使用TypeScript開發(fā)Node.js應(yīng)用
首先配置package.json
因為要在項目中使用Webpack,所以首先得創(chuàng)建一個package.json文件,我們可以使用npm init來生成
{ "name": "start", "version": "1.0.0", "description": "", "main": "index.js", "scripts": { "test": "echo "Error: no test specified" && exit 1" }, "author": "", "license": "ISC" }
后面用到其他的在添加
開始
我們在項目的根目錄創(chuàng)建一個src目錄,添加一個main.js和information-logger.js文件,我們先使用Javascript來創(chuàng)建:
// src/information-logger.js const os = require('os'); const { name, version} = require('../package.json'); module.exports = { logApplicationInformation: () => console.log({ application: { name, version, }, }), logSystemInformation: () => console.log({ system: { platform: process.platform, cpus: os.cpus().length, }, }), }; // src/main.js const informationLogger = require('./information-logger'); informationLogger.logApplicationInformation(); informationLogger.logSystemInformation();
我們先運(yùn)行一下:node main.js(先到src目錄下),打印了我的筆記本電腦的信息
Webpack
首先第一件事就是要配置Webpack的依賴項,記得用下面的命令,帶上 -d,因為我們只在開發(fā)環(huán)境下
npm i -D webpack webpack-cli
我們沒用到webpack-dev-server,安裝完成后我們創(chuàng)建webpack.config.js的配置文件
'use strict'; module.exports = (env = {}) => { const config = { entry: ['./src/main.js'], mode: env.development ? 'development' : 'production', target: 'node', devtool: env.development ? 'cheap-eval-source-map' : false, }; return config; };
最開始我們沒那么多的配置需要配置。我們要使用它,先改一下package.json
“scripts”:{ “start”:“webpack --progress --env.development”, “start :prod”:“webpack --progress” },
然后我們就可以通過任一命令(npm start)來構(gòu)建應(yīng)用程序,它會創(chuàng)建一個dist/main.js,我們可也使用webpack.config.js指定輸出不同的名稱,現(xiàn)在的目錄結(jié)構(gòu)應(yīng)該如下
nodemon
為什么不用webpack-dev-server,是因為沒法用,所以可以使用nodemon來解決,它可以在我們開發(fā)期間重新啟動Node.js的應(yīng)用程序,一樣我們先來安裝,依然需要 -d
npm i -D nodemon-webpack-plugin
然后重新配置webpack.config.js
// webpack.config.js 'use strict'; const NodemonPlugin = require('nodemon-webpack-plugin'); module.exports = (env = {}) => { const config = { entry: ['./src/main.js'], mode: env.development ? 'development' : 'production', target: 'node', devtool: env.development ? 'cheap-eval-source-map' : false, resolve: { // tells Webpack what files to watch. modules: ['node_modules', 'src', 'package.json'], }, plugins: [] // required for config.plugins.push(...); }; if (env.nodemon) { config.watch = true; config.plugins.push(new NodemonPlugin()); } return config; };
Webpack 監(jiān)視配置將在我們更改文件時重建應(yīng)用程序,nodemon在我們構(gòu)建完成重新啟動應(yīng)用程序,需要重新配置下package.json
"scripts": { "start": "webpack --progress --env.development --env.nodemon", "start:prod": "webpack --progress --env.nodemon", "build": "webpack --progress --env.development", "build:prod": "webpack --progress", "build:ci": "webpack" },
使用TypeScript
先安裝依賴項
npm i -D typescript ts-loader @types/node@^10.0.0
ts-loader(ts加載器)
因為要用ts-loader Webpack插件來編譯我們的TypeScript,所以得讓W(xué)ebpack知道我們是使用了ts-loader插件來處理TypeScript文件的,更新之前的webpack.config.js
// webpack.config.js 'use strict'; const NodemonPlugin = require('nodemon-webpack-plugin'); module.exports = (env = {}) => { const config = { entry: ['./src/main.ts'], mode: env.development ? 'development' : 'production', target: 'node', devtool: env.development ? 'cheap-eval-source-map' : false, resolve: { // Tells Webpack what files to watch extensions: ['.ts', '.js'], modules: ['node_modules', 'src', 'package.json'], }, module: { rules: [ { test: /.ts$/, use: 'ts-loader', }, ], }, plugins: [], // Required for config.plugins.push(...); }; if (env.nodemon) { config.watch = true; config.plugins.push(new NodemonPlugin()); } return config; };
tsconfig.json
TypeScript的配置文件
// tsconfig.json { "compilerOptions": { "target": "esnext", "module": "esnext", "moduleResolution": "node", "lib": ["dom", "es2018"], "allowSyntheticDefaultImports": true, "noImplicitAny": true, "noUnusedLocals": true, "removeComments": true, "resolveJsonModule": true, "strict": true, "typeRoots": ["node_modules/@types"] }, "exclude": ["node_modules"], "include": ["src/**/*.ts"] }
然后更改下之前創(chuàng)建的js文件擴(kuò)展名
// information-logger.ts import os from 'os'; import { name, version } from '../package.json'; export class InformationLogger { static logApplicationInformation(): void { console.log({ application: { name, version, }, }); } static logSystemInformation(): void { console.log({ system: { platform: process.platform, cpus: os.cpus().length, }, }); } } // main.ts import { InformationLogger } from './information-logger'; InformationLogger.logApplicationInformation(); InformationLogger.logSystemInformation();
現(xiàn)在目錄結(jié)構(gòu)應(yīng)該是這樣的
總結(jié)
我們可以使用多種方式來創(chuàng)建TypeScript的Nodejs應(yīng)用,不必拘泥于這一種,而且可能會有人并不贊同,因為TypeScript比純Javascript更需要花費(fèi)更多精力,不過在新項目中,你仍然可以嘗試這種方式,如果你有什么好的建議,歡迎在評論區(qū)留下你的意見!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Node.js結(jié)合FFmpeg構(gòu)建自動化腳本實現(xiàn)轉(zhuǎn)碼視頻
傳統(tǒng)的視頻轉(zhuǎn)碼中,很常用的工具是FFmpeg,本文主要介紹了Node.js結(jié)合FFmpeg構(gòu)建自動化腳本實現(xiàn)轉(zhuǎn)碼視頻,具有一定的參考價值,感興趣的可以了解一下2024-04-04Node.js用readline模塊實現(xiàn)輸入輸出
在學(xué)C++的時候,有cout和cin,Java也有println和Scanner控件,Node.js也有如同C++和Java的標(biāo)準(zhǔn)輸入,當(dāng)然,是用JavaScript實現(xiàn)的,它就是Readline模塊。下面這篇文章就給大家詳細(xì)介紹一下readline模塊,來實現(xiàn)Node.js的控制臺輸入輸出。有需要的可以參考借鑒。2016-12-12Nodejs進(jìn)階:如何將圖片轉(zhuǎn)成datauri嵌入到網(wǎng)頁中去實例
這篇文章主要介紹了Nodejs進(jìn)階:如何將圖片轉(zhuǎn)成datauri嵌入到網(wǎng)頁中去,有興趣的可以了解一下。2016-11-11使用Nodejs連接mongodb數(shù)據(jù)庫的實現(xiàn)代碼
這篇文章主要介紹了使用Nodejs連接mongodb數(shù)據(jù)庫的實現(xiàn)代碼,需要的朋友可以參考下2017-08-08快速掌握Node.js之Window下配置NodeJs環(huán)境
快速掌握Node.js之Window下配置NodeJs環(huán)境,如何在Window下快速配置NodeJs環(huán)境,感興趣的小伙伴們可以參考一下2016-03-03Node實現(xiàn)前端本地開發(fā)接口代理服務(wù)
本文主要介紹了Node實現(xiàn)前端本地開發(fā)接口代理服務(wù),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05