调试快速服务器时,我的“构建和运行”过程包括3个步骤:
tsc
编译TypeScript源代码dist/
server.js
文件这些步骤中的每一步都可以使用手表模式自动完成,但我很难将三者合并在一起。我设法通过使用tsc-watch来观察TypeScript源,cpx来复制静态文件,最后使用nodemon来重启服务器。这种方法有效,但有几个问题:
cpx
只监视它开始时存在的文件(我认为tsc-watch
有时会这样做,这有点奇怪)cpx
和tsc-watch
都没有正确处理Ctrl+C
退出,导致各种问题我found some other questions与这个主题有关,但他们都没有解决上述问题(虽然他们确实告诉我有关cpx和tsc-watch的信息)。我不想使用concurrently,因为它可能导致计时问题,它混合了来自不同进程的控制台输出(最值得注意的是tsc-watch
和实际的服务器)。
使用tsc-watch
'es --onSuccess
复制静态文件是不够的,因为模板文件中的更改将无法获取。这可以通过更改源文件中的注释来解决,但这会触发完整的重新编译(重新启动服务器)。使用webpack's watch mode也不够,因为它不会接收新文件并且会更多地污染控制台输出。
有没有我可能错过的解决方案?我应该编写一个自动打开3个所需终端的脚本吗?
我最终用webpack去找copy-webpack-plugin。
尽管在编写本报告时手表模式不幸是broken,但它似乎几乎完全符合我的需求:
Ctrl+C
退出