发布时间:2023-11-26 18:00
与之前使用JavaScript
开发后台不同,区别如下:
nodemon
替换为ts-node-dev
。TypeScript
环境下,需要使用到ES6
模块化规范。而非CommonJS
规则。TypeScript
语法进行开发,再开发结束后,需要进行编译打包为JavaScript
去运行。yarn global add ts-node-dev typescript
ts-node-dev:与nodemon
功能类似,在修改代码之后,保存即可生效,无需手动重启。
# 例如 ts-node-dev src/app.ts # 如果想要监听文件的改变需要加上 --respawn 参数 ts-node-dev --respaswn src/app.ts # 使用简短的别名 tsnd --respawn src/app.ts
# 生成tsconfig.json tsc --init
修改tsconfig.json
如下:
{ \"compilerOptions\": { \"target\": \"esnext\", // 目标语言版本 \"module\": \"commonjs\", // 指定生成代码的模板标准 \"sourceMap\": true, \"outDir\": \"./dist\", \"rootDir\": \"./src\", // 指定输出目录, 默认是dist文件夹 \"strict\": true, \"esModuleInterop\": true, \"allowSyntheticDefaultImports\": true, \"skipLibCheck\": true, \"forceConsistentCasingInFileNames\": true }, // 需要编译的的文件和目录 \"include\": [\"src\"], \"exclude\": [\"node_modules\", \"dist\", \"public\"] }
# 依赖安装 yarn add koa yarn add typescript -D # 依赖注解 yarn add @types/koa -D
再app.ts
中实例化一个服务器。
import Koa, { DefaultContext, DefaultState, Context } from \'Koa\' const app: Koa= new Koa() app.use(async (ctx: Context) => { ctx.body = \'coderlzw\' }) app.listen(3000, () => { console.log(\'服务启动成功,running http://127.0.0.1:3000\') })
再package.json
中添加调试脚本:
\"scripts\": { \"dev\": \"ts-node-dev --respawn app.ts\" }
启动服务:
现在,我们使用Koa
和TypeScript
搭建了一个简单的服务器,我们http://127.0.0.1:3000便可以再浏览器中看到”coderlzw“
# 依赖安装 yarn add koa koa-router koa-cors koa-bodyparser dotenv yarn add ts-node-dev npm-run-all typescript -D # 依赖注解 yarn add @types/koa @types/koa-bodyparser @types/koa-router @types/koa-cors -D
dotenv
是一个零依赖的模块,它能将环境变量中的变量从.env
文件加载到process.env
中。
在根目录下创建.env
文件
HOST=localhost PORT=3000
在*.js/*.ts
中使用
import dotenv from \'dotenv\' dotenv.config() const { PORT, HOST } = process.env
npm-run-all
是一个批量执行npm
脚本的工具。
service ├─ package.json ├─ src │ ├─ app │ ├─ config │ ├─ constants │ ├─ controller │ ├─ main.ts │ ├─ middleware │ ├─ router │ ├─ service │ └─ utils ├─ .env ├─ tsconfig.json └─ yarn.lock
{ \"script\": { \"dev\": \"tsnd --respawn src/main.ts\", \"build\": \"npm-run-all resetFolder compile\", \"compile\": \"tsc\", // 编译typescript \"resetFolder\": \"rimraf dist/*\" // 清空dist文件夹 } }
当我们在开发环境的时候,只需要执行yarn dev
即可成功启动服务。
当我们执行编译打包的时候,根据tsconfig.json
中的配置输出到指定的目录。
在项目部署后,我们只需要运行dist/main.js
文件即可启动服务。
官网: eslint.bootcss.com
eslint
能够帮助我们规范编码,比如字符串使用哪种引号,代码结尾是否要有分号等等。
接着我们在命令行执行:npx eslint src/** --fix
,执行eslint
提供的代码的自动修复。
修改package.json
,添加运行脚本。
\"scripts\": { \"lint\": \"eslint src/** --fix\", // 使用eslint规则格式化代码 }
现在我们可以通过命令来处理代码风格问题,但是我们更加希望在保存的时候自动处理代码分格,这时候就需要使用到vscode
编辑器的插件ESLint
,通过此插件和vscode
编辑器配置便可以实现保存的时候自动格式化代码。
// vscode 配置自动格式化 \"editor.codeActionsOnSave\": { \"source.fixAll\": true }
现在我们通过如上的配置,在保存的时候就会自动处理代码风格问题。
前面所提到的eslint
主要做两件事情,一是修复代码质量,二是修改代码分格。
如果你不喜欢eslint
自带的格式化方式,就可以使用prettier
来格式化代码分格。
官网: prettier.io/
yarn add prettier -D 复制代码
在项目更目录下配置.prettierrc
{ \"useTabs\": false, \"tabWidth\": 2, \"printWidth\": 100, \"singleQuote\": true, \"trailingComma\": \"none\", \"bracketSpacing\": true, \"semi\": false }
在项目更目录运行如下命令,格式化项目所有文件。
npx prettier --write .
但是当我们执行完后,会发现eslint
又报错了。这是因为eslint
和prettier
的冲突所导致的。这时候我们需要关闭prettier
与eslint
格式所产生的冲突。
yarn add eslint-config-prettier -D
然后在.eslintrc.js
加入perttier
扩展,配置后冲突的问题就解决了,代码分格就由prettier
来处理。
extends: [\'standard\', \'prettier\']
现在我们希望在保存的时候按照prettier
的代码分格格式化代码。eslint-plugin-prettier
yarn add eslint-plugin-prettier -D
eslintrc.js
的最终配置如下:
module.exports = { env: { browser: true, es2021: true }, extends: [\'standard\', \'plugin:prettier/recommended\'], // 修改此处 parser: \'@typescript-eslint/parser\', parserOptions: { ecmaVersion: \'latest\', sourceType: \'module\' }, plugins: [\'@typescript-eslint\'], rules: { camelcase: 0 // 驼峰命名 } }
最后,实现了一个小案例:gitee.com/coderlzw/ko…
到此这篇关于使用 Koa + TS + ESLlint 搭建node服务器的文章就介绍到这了,更多相关node服务器搭建内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
报错ImportError: numpy.core.multiarray failed to import
springboot+redis+mysql+vue入门项目(含调用阿里云SDK短信服务)
android 架构师jd,在京东,做架构师是一种什么样的体验?
dynamic + shardingsphere(4.1.1) 实现动态分库分表
软件工程概论-- 详细设计,过程设计的工具:程序流程图,判定表,N-S图和判定树之间的区别, PAD图的优点?
视觉/视觉惯性SLAM最新综述:领域进展、方法分类与实验对比
基于IIC协议的4脚OLED模块的单片机驱动控制(含驱动程序)
解决draw.io生成SVG矢量图导入Word显示有误的问题以及推荐几种SVG绘图方法
【GoggLeNet 的 inception 结构】 与 【ResNet 的 Residual 结构】 tensor拼接方式的区别