Step 1 创建基础和安装依赖

mkdir <project-name>
cd <project-name>
git init // 初始化 git 配置文件
mkdir src// 安装依赖
npm init // 初始化 package.json
npm i koa koa-router
npm i --save-dev typescript ts-node nodemon
npm i --save-dev @types/koa @types/koa-router

Step 2 修改编译配置

添加 tsconfig.json 配置,为了使用原生的 Async/Await,我们将编译的目标版本设置为 es2017:

{"compilerOptions": {"module": "commonjs","target": "es2017","noImplicitAny": true,"moduleResolution": "node","sourceMap": true,"outDir": "dist",  // TS文件编译后会放入到此文件夹内"baseUrl": ".","paths": {"*": ["node_modules/*","src/types/*"]}},"include": ["src/**/*"]
}

Step 3 创建 koa 应用

我们在 src目录下创建文件 server.ts


import * as Koa from 'koa';
import * as Router from 'koa-router';const app = new Koa();
const router = new Router();router.get('/', async (ctx) => {ctx.body = 'Hello World!';
});app.use(router.routes());app.listen(3000);console.log('Server running on port 3000');

Step 4 启动项目

我们添加一些脚本到 package.json 中,脚本如下

"scripts": {"start": "tsc && node dist/server.js"
}

然后我们使用以下命令,启动项目

npm start

tsc 命令会根据 tsconfig.json中配置,对我们 ts 文件进行编译,并将生成的文件放入 dist目录下。然后我们使用 node server.js命令,启动服务。

启动后,我们可以通过 http://localhost:3000 访问页面。

参考:
链接:https://www.jianshu.com/p/1a91f36e5153

我是在这里 https://www.jianshu.com/p/1a91f36e5153找的,要感谢原作者。

但是出了问题,困扰我很久。但是在这篇文章中我已经改了。下面是执行npm start 命令时报错的地方:

TypeError: Unexpected MODIFIER at 1, expected ENDat mustConsume (/home/ksuser/Downloads/projectwjl/text01/lastbed/node_modules/path-to-regexp/dist/index.js:114:15)at parse (/home/ksuser/Downloads/projectwjl/text01/lastbed/node_modules/path-to-regexp/dist/index.js:173:9)at stringToRegexp (/home/ksuser/Downloads/projectwjl/text01/lastbed/node_modules/path-to-regexp/dist/index.js:331:27)at pathToRegexp (/home/ksuser/Downloads/projectwjl/text01/lastbed/node_modules/path-to-regexp/dist/index.js:405:12)at new Layer (/home/ksuser/Downloads/projectwjl/text01/lastbed/node_modules/koa-router/lib/layer.js:43:17)at Router.register (/home/ksuser/Downloads/projectwjl/text01/lastbed/node_modules/koa-router/lib/router.js:570:17)at Router.<computed> [as get] (/home/ksuser/Downloads/projectwjl/text01/lastbed/node_modules/koa-router/lib/router.js:200:12)at Object.<anonymous> (/home/ksuser/Downloads/projectwjl/text01/lastbed/dist/index.js:7:8)at Module._compile (internal/modules/cjs/loader.js:1015:30)at Object.Module._extensions..js (internal/modules/cjs/loader.js:1035:10)
npm ERR! code ELIFECYCLE
npm ERR! errno 1
npm ERR! lastbed@1.0.0 start: `tsc && node dist/index.js`
npm ERR! Exit status 1
npm ERR!
npm ERR! Failed at the lastbed@1.0.0 start script.
npm ERR! This is probably not a problem with npm. There is likely additional logging output above.npm ERR! A complete log of this run can be found in:
npm ERR!     /home/ksuser/.npm/_logs/2022-02-07T09_04_41_653Z-debug.log

找了很久很久,好吧,问题出在了 原作者是

router.get('/*, async (ctx) => {
    ctx.body = 'Hello World!';
});   我把*删了,重新tsc了一下。就启动成功了


import * as Koa from 'koa';
import * as Router from 'koa-router';const app = new Koa();
const router = new Router();router.get('/', async (ctx) => {ctx.body = 'Hello World!';
});app.use(router.routes());app.listen(3000);console.log('Server running on port 3000');

成功页面:

如何实现热更新

这时,有一个问题 —— 当我们文件发生改变时,我们需要终止命令,然后重启命令。这样,开发起来太繁琐了。能不能当文件发生改变时,自动重新编译和启动项目。于是,我们想到了使用 nodemon来监控文件的改变, 使用ts-node(类似,执行了 tsc && node dist/server.js)启动项目。

我们将启动脚本改成如下:

"scripts": {"start": "tsc && node dist/server.js","watch-server": "nodemon --watch 'src/**/*' -e ts,tsx --exec 'ts-node' ./src/server.ts"
}

然后执行 npm run watch-server启动项目,尝试修改 server.ts文件,我们可以发现文件可以自动编译了。

如何使用 chrome 的 debug 模式

开发时,我们有时希望可以进行断点调试。我们想到了使用node的--inspect参数启动node项目,然后通过chrome 进行调试。

我们修改一下启动命令:

    "watch-server": "nodemon --inspect --watch 'src/**/*' -e ts,tsx --exec 'node -r ts-node/register' ./src/server.ts",

启动项目后,我们可以通过chrome控制台进入调试窗口进行调试

koa +ts 搭建简单项目相关推荐

  1. 使用vue-cli脚手架搭建简单项目框架

    1.首先已经安装了node,最好版本6以上. 2.安装淘宝镜像 大家都知道国内直接使用 npm 的官方镜像是非常慢的,这里推荐使用淘宝 NPM 镜像.这样就可以直接使用cnpm了. npm insta ...

  2. 零配置简单搭建SpringMVC 项目

    SpringMVC是比较常用的JavaWeb框架,非常轻便强悍,能简化Web开发,大大提高开发效率,在各种Web程序中广泛应用.本文采用Java Config的方式搭建SpringMVC项目,并对Sp ...

  3. 搭建vue项目环境以及创建一个简单的vue的demo

    一.vue-cli脚手架的搭建步骤 1.首先,确定你的电脑上已经安装了nodejs,可以使用npm包管理器安装环境,如果还没有安装node环境,则需要安装node.js 这个很简单    默认点击安装 ...

  4. 搭建React项目,超简单教程

    步骤 前言 一.安装create-react-app 二.使用步骤 1.创建项目 2.运行项目 3.文件目录 总结 前言 最近公司闲的无聊,刚好之前学的React,至今还未搭建过一个React项目,借 ...

  5. SSM+MyBatis-Plus+EasyExcel+腾讯云tianai滑动验证码接入项目搭建+简单实现增、删、改、查、导入、滑动验证码功能

    SSM+MyBatis-Plus+EasyExcel+腾讯云&tianai滑动验证码接入项目搭建+简单实现增.删.改.查.导入.滑动验证码功能 文章末尾附源码 一.什么是SSM框架 SSM框架 ...

  6. SpringBoot简单项目搭建,从数据读取数据展示到页面

    springboot快速搭建web项目,无需繁琐xml配置,热部署,无需重启服务器,简单部署只需打jar包即可,有很多的优点! 刚接触到springboot花费了好几个小时,撸完一个又一个的配置坑,最 ...

  7. 利用IDEA搭建SpringBoot项目,整合mybatis,实现简单的登录功能。

    利用IDEA搭建SpringBoot项目,整合mybatis,实现简单的登录功能. 仅供参考!!! 仅供参考!!! 仅供参考!!! 利用闲余时间想自己搭建一个springboot+mybatis的项目 ...

  8. 使用Idea简单搭建springcloud项目

    前言: 开发工具:IntelliJ IDEA 2020版 (Ultimate Edition) 框架:spring boot .spring cloud 搭建一套spring cloud微服务系统,实 ...

  9. 从零开始使用webpack 搭建vue项目

    从零开始使用webpack 搭建vue项目 1 创建项目 npm init 生成 package.json 创建 index.html webpack.confug.js project-name|- ...

最新文章

  1. 大道至简:算法工程师炼丹Trick手册
  2. VS2013_QT5.4_静态编译问题_已经解决
  3. power designer 连接数据库提示“connection test failed”
  4. 回归统计在DMP中的实战应用
  5. EXC_BAD_ACCESS
  6. js时间搓化为今天明天_秋冬国产搓背神器!360°无死角,让你搓背不求人,太舒服了...
  7. JAVA入门级教学之(简单的程序测试)
  8. 建议把英语改成选修的计算机老师,中小学“变动”,英语改为副科?老师没意见家长却愁眉不展...
  9. 阿里程序员发70多万年终奖表示略感失望,网友:不要的话请给我!
  10. FlowDocumentPageViewer
  11. Mikogo新版本已支持Linux系统
  12. 字符串函数-STUFF函数
  13. sap未分摊差异怎么处理_MM采购中形成的差异
  14. 根据输入时间判断年龄是否在18~68周岁之间
  15. 如何学习HyperMesh
  16. 方维带货直播最新搭建教程《9》-常见问题总结
  17. [图像处理-1]:颜色中英文对照表 颜色名字 色彩名称
  18. C++ int a= {}和int a = 0
  19. arr.map()的使用
  20. JVM - 垃圾回收相关算法

热门文章

  1. 暴风播酷云二期J3455 DS918 1.04b引导6.23完美群晖教程,可硬洗,正常开关机、WOL
  2. X1 carbon 2015安装win7、win10后触控板驱动安装失败(双指滑动无效、多指操作无效)的另类解决之道
  3. 时间序列分析之一次指数平滑法
  4. android五层系统架构,Android系统的五层架构、Dalvik与ART、最后有个奇怪的问题请教orz...
  5. WP8.1小梦词典开发1:金山词霸API使用
  6. HTTP状态码@蓝神
  7. Linux 网络延迟排查方法
  8. VS2015+WDK10在不同环境下的驱动配置
  9. 百度地图基本使用及画线路轨迹播放问题
  10. 奥塔在线:Centos7下NTP服务的详细部署说明