Nest:REPL 控制台调试大法

什么是 REPL?

在开发 Nest.js 应用时,通常需要在浏览器中访问特定 URL 并通过 GET 或 POST 方式传参来测试模块、服务和控制器,这种方法虽然有效,但有时候可能会显得繁琐。

Nest.js 提供了 REPL 模式,类似于 Node.js 的 REPL,允许开发者在控制台中直接测试代码。

创建 Nest 项目:

bash 复制代码
nest new repl-test -p npm

创建 test 模块:

运行项目:

typescript 复制代码
npm run start:dev

运行 repl 模式

在 src 下创建 repl.ts,内容如下:

重新通过这种方式运行项目:

bash 复制代码
npm run start:dev -- --entryFile repl

其中 --entryFile 用于指定入口文件为 repl.ts

REPL 模式下的操作

使用 debug() 查看所有模块以及模块下的控制器和提供者:

methods() 查看某个控制器或提供者的方法:

使用 get()$() 获取提供者或控制器的实例并调用其方法:

注意事项:REPL 模式下,直接调用的方法不会触发管道(pipe)、拦截器(interceptor)等,仅用于传参测试函数。

配置命令历史

为了保留命令历史,可以按住上下键进行历史导航,可以在 repl.ts 中添加历史设置代码:

typescript 复制代码
import { repl } from '@nestjs/core';
import { AppModule } from './app.module';

async function bootstrap() {
  const replServer = await repl(AppModule);
  replServer.setupHistory('.nestjs_repl_history', (err) => {
    if (err) {
      console.error(err);
    }
  });
}
bootstrap();

最后我们可以把命令配置到 npm script:

bash 复制代码
"repl:dev": "npm run start:dev -- --entryFile repl",
相关推荐
张耘华3 分钟前
nosqlbooster pojie NoSQLBooster for MongoDB
node.js
Chris馒头8 分钟前
Node打包报错:Error: error:0308010C:digital envelope routines::unsupported
node.js
隐含44 分钟前
webpack打包,把png,jpg等文件按照在src目录结构下的存储方式打包出来。解决同一命名的图片资源在打包之后,重复命名的图片就剩下一个图片了。
前端·webpack·node.js
lightYouUp1 小时前
windows系统中下载好node无法使用npm
前端·npm·node.js
Dontla1 小时前
npm cross-env工具包介绍(跨平台环境变量设置工具)
前端·npm·node.js
小妖6661 小时前
vue2 切换主题色以及单页面好使方法
前端·vue.js·elementui
胡桃夹夹子1 小时前
【前端优化】vue2 webpack4项目升级webpack5,大大提升运行速度
前端·javascript·vue.js·webpack·性能优化
Stringzhua1 小时前
JavaScript【7】BOM模型
开发语言·前端·javascript
阿幸软件杂货间1 小时前
谷歌浏览器(Google Chrome)136.0.7103.93便携增强版|Win中文|安装教程
前端·chrome
繁依Fanyi2 小时前
Animaster:一次由 CodeBuddy 主导的 CSS 动画编辑器诞生记
android·前端·css·编辑器·codebuddy首席试玩官