<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

        手把手教你使用TypeScript開發(fā)Node.js應(yīng)用

        來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 21:57:30
        文檔

        手把手教你使用TypeScript開發(fā)Node.js應(yīng)用

        手把手教你使用TypeScript開發(fā)Node.js應(yīng)用:為什么要使用TypeScript? 為了減少代碼編寫過程中出現(xiàn)的錯(cuò)誤,以及更好的維護(hù)你的項(xiàng)目,本文將手把手教你配置一個(gè)簡單的開發(fā)環(huán)境來編寫Node.js的應(yīng)用程序,創(chuàng)建這樣的一個(gè)開發(fā)環(huán)境有很多方式,這只是其中一種,希望對(duì)你有所幫助! 手把手教你使用Type
        推薦度:
        導(dǎo)讀手把手教你使用TypeScript開發(fā)Node.js應(yīng)用:為什么要使用TypeScript? 為了減少代碼編寫過程中出現(xiàn)的錯(cuò)誤,以及更好的維護(hù)你的項(xiàng)目,本文將手把手教你配置一個(gè)簡單的開發(fā)環(huán)境來編寫Node.js的應(yīng)用程序,創(chuàng)建這樣的一個(gè)開發(fā)環(huán)境有很多方式,這只是其中一種,希望對(duì)你有所幫助! 手把手教你使用Type

        為什么要使用TypeScript?

        為了減少代碼編寫過程中出現(xiàn)的錯(cuò)誤,以及更好的維護(hù)你的項(xiàng)目,本文將手把手教你配置一個(gè)簡單的開發(fā)環(huán)境來編寫Node.js的應(yīng)用程序,創(chuàng)建這樣的一個(gè)開發(fā)環(huán)境有很多方式,這只是其中一種,希望對(duì)你有所幫助!

        手把手教你使用TypeScript開發(fā)Node.js應(yīng)用

        首先配置package.json

        因?yàn)橐陧?xiàng)目中使用Webpack,所以首先得創(chuàng)建一個(gè)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" 
        } 

        后面用到其他的在添加

        開始

        我們?cè)陧?xiàng)目的根目錄創(chuàng)建一個(gè)src目錄,添加一個(gè)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的依賴項(xiàng),記得用下面的命令,帶上 -d,因?yàn)槲覀冎辉陂_發(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)用程序,它會(huì)創(chuàng)建一個(gè)dist/main.js,我們可也使用webpack.config.js指定輸出不同的名稱,現(xiàn)在的目錄結(jié)構(gòu)應(yīng)該如下

        nodemon

        為什么不用webpack-dev-server,是因?yàn)闆]法用,所以可以使用nodemon來解決,它可以在我們開發(fā)期間重新啟動(dòng)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)視配置將在我們更改文件時(shí)重建應(yīng)用程序,nodemon在我們構(gòu)建完成重新啟動(dòng)應(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

        先安裝依賴項(xiàng)

        npm i -D typescript ts-loader @types/node@^10.0.0 

        ts-loader(ts加載器)

        因?yàn)橐胻s-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)用,不必拘泥于這一種,而且可能會(huì)有人并不贊同,因?yàn)門ypeScript比純Javascript更需要花費(fèi)更多精力,不過在新項(xiàng)目中,你仍然可以嘗試這種方式,如果你有什么好的建議,歡迎在評(píng)論區(qū)留下你的意見!

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        手把手教你使用TypeScript開發(fā)Node.js應(yīng)用

        手把手教你使用TypeScript開發(fā)Node.js應(yīng)用:為什么要使用TypeScript? 為了減少代碼編寫過程中出現(xiàn)的錯(cuò)誤,以及更好的維護(hù)你的項(xiàng)目,本文將手把手教你配置一個(gè)簡單的開發(fā)環(huán)境來編寫Node.js的應(yīng)用程序,創(chuàng)建這樣的一個(gè)開發(fā)環(huán)境有很多方式,這只是其中一種,希望對(duì)你有所幫助! 手把手教你使用Type
        推薦度:
        標(biāo)簽: js 手把手教你 node.js
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲国产成+人+综合| 亚洲成人网在线播放| 特级毛片免费播放| 国产免费观看黄AV片| 亚洲欧美乱色情图片| 日韩免费视频在线观看| 久久亚洲精品无码gv| 国产小视频免费观看| 牛牛在线精品观看免费正| 国产精品亚洲综合一区| a级毛片在线免费| 久久亚洲精品国产精品| 亚洲视频免费观看| 亚洲欧美黑人猛交群| 亚洲毛片av日韩av无码| 国产成人免费ā片在线观看老同学| 久久亚洲AV午夜福利精品一区| 午夜免费福利视频| 亚洲国产日韩综合久久精品| 日韩精品视频免费网址| 国产久爱免费精品视频 | 亚洲午夜无码久久久久软件| 日韩免费观看的一级毛片| 日本免费精品一区二区三区| 国产亚洲大尺度无码无码专线 | 亚洲人成网站观看在线播放| 日本亚洲欧洲免费天堂午夜看片女人员| 亚洲国产成人一区二区三区| 亚洲一区二区三区免费视频| 亚洲精品久久无码av片俺去也| 亚洲AV无码乱码在线观看牲色| 光棍天堂免费手机观看在线观看| 亚洲乱码卡一卡二卡三| 国产精品亚洲精品日韩已方| 久久久久高潮毛片免费全部播放| 亚洲色一区二区三区四区| 一本色道久久综合亚洲精品| 四虎精品视频在线永久免费观看| 国产区图片区小说区亚洲区| 水蜜桃亚洲一二三四在线| 日韩视频免费一区二区三区|