koa2-typescript开发后台


本文目的

  • 学习 typescript 在后端中的应用。typescript 是 javascript 的超集,他提供了静态语言强类型的支持,可以在项目编译阶段提早发现类型的错误,避免在项目在运行阶段才出现,提高代码开发效率。
  • 结合当前流行的 koa 框架,快速上手 typescript 在后端开发中的使用,使之有真正能输出的项目。
  • 代码仓库:https://github.com/ddzyan/koa2-ts

如何创建 koa/typescript 项目

本文首选不采用脚手架的方式创建项目,目的在于了解项目的基础结构。

创建基础文件

mkdir src dist

npm init

npm i koa --save

npm i --save-dev @types/koa tslint typescript

tsconfig.json

{
  "compilerOptions": {
    "module": "commonjs",
    "target": "es2015",
    "noImplicitAny": true,
    "moduleResolution": "node",
    "sourceMap": true,
    "outDir": "dist",
    "baseUrl": ".",
    "paths": {
      "*": ["node_modules/*", "src/types/*"]
    }
  },
  "include": ["src/**/*"],
  "exclude": ["node_modules"]
}

./src/server.ts

debugger;

import * as Koa from 'koa';
const app = new Koa();

app.use(ctx => {
  ctx.body = 'hello word';
});

app.listen(3000, () => {
  console.log('Server is running at http://localhost:3000');
  console.log('Press CTRL-C to stop \n');
});

module.exports = app;

修改 package.json

"scripts": {
    "tsc": "tsc",
    "tsc:w": "tsc -w"
 }

.vscode 目录

  • launch.json 添加 debug 配置
{
  // 使用 IntelliSense 了解相关属性。
  // 悬停以查看现有属性的描述。
  // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
  "version": "0.2.0",
  "configurations": [
    {
      "name": "Current JS File",
      "type": "node",
      "request": "launch",
      "program": "${workspaceRoot}/dist/server.js",
      "args": [],
      "cwd": "${workspaceRoot}",
      "protocol": "inspector"
    },
    {
      "type": "node",
      "request": "launch",
      "name": "Launch Program",
      "program": "${workspaceFolder}/dist/server.js",
      "preLaunchTask": "npm: build",
      "outFiles": ["${workspaceFolder}/dist/**/*.js"]
    }
  ]
}
  • tasks.json
{
  // 有关 tasks.json 格式的文档,请参见
  // https://go.microsoft.com/fwlink/?LinkId=733558
  "version": "2.0.0",
  "tasks": [
    {
      "type": "typescript",
      "tsconfig": "tsconfig.json",
      "option": "watch",
      "problemMatcher": ["$tsc-watch"]
    }
  ]
}

点击 vscode 终端 —> 运行任务 —>ts watch:typescript.json,之后每次编辑 ts 文件将自动转编译为 js 文件

启动

Launch Program ,点击 F5 将直接运行转换后的 js 文件,调试转换后的 js 代码

直接调试

ts-node 调试 ts 文件时,不会显式生成 js。假如你不想编译为 js 后 在调试,可以考虑这种方式。

安装依赖
npm i ts-node --save-dev

添加 launch.json

{
  "name": "Current TS File",
  "type": "node",
  "request": "launch",
  "program": "${workspaceRoot}/node_modules/ts-node/dist/_bin.js",
  "args": ["${relativeFile}"],
  "cwd": "${workspaceRoot}",
  "protocol": "inspector"
}

在 server.ts 头部添加 debugger,上面代码已经存在

插入断点,选择指定的 debug 模式,F5 运行


 上一篇
nodejs生成脚手架 nodejs生成脚手架
资料 代码示例仓库:https://github.com/ddzyan/chain-cli 参考文章 https://github.com/lin-xin/blog/issues/27 https://github.com/ykfe/koa
2019-08-21
下一篇 
docker打包node项目 docker打包node项目
简介常规操作的问题一个项目成功运行需要依赖于:系统版本,代码版本,运行环境,依赖包版本等综合因素控制。如果我们提交代码给运行只提交代码版本,可能会导致因为其他依赖不同,而产生的各种问题。 在 node 中即使使用 package-lock.
2019-06-11
  目录