❗️项目已经迁移到https://github.com/nailyjs/core,本仓库不再更新,请注意
基于 Express 实现了一个简易的,无模块系统的 Nest.js。
自动依赖注入特性+无模块系统,企业级开发就算啦,写着玩的,代码写得很垃圾。
只支持
TypeScript
,没去特别适配 JavaScript 和 Babel 转译器。如果使用有问题别问我(
需有node^12
+ pnpm
环境,然后运行 cli 命令:
pnpx naily
main.ts
// 注入你写的控制器
// 必须在导入app对象之前导入 才能被检测到并挂载
import "./main.controller";
// 所有控制器导入之后再导入此装饰器!
import { BootNailyApplication, type CanBoot, IMount } from "../src/app";
@BootNailyApplication
export class Booter implements CanBoot {
// 实现了main函数
main(app: IMount): void {
app.boot(8000);
}
}
app
// 使用useMiddleware创建中间件
.useMiddleware((req, res, next) => {
// 这里编写您的中间件...
})
// 使用useFilter将在全局挂载Filter
.useFilter(MyFilter)
// 最后使用boot启动服务器
.boot(8000);
main.controller.ts
// 导入控制器注解和GET方法注解
import { GetMapping, RequestIp, RestController } from "naily";
// 导入一个服务
import { AppService } from "./main.service";
// 这里导出一个类 用controller装饰起来~
@RestController()
export class AppController {
// 这里注入一个服务~
constructor(private readonly appService: AppService) {}
// 这里用get装饰起来~
@GetMapping()
// 使用@RequestIp可以获取到请求发出地的IP地址哦
public getHello(@RequestIp ip: string) {
// 返回一个JSON对象吧
return {
ip: ip,
data: this.appService.getData(),
message: "Hello world",
};
}
}
main.service.ts
import { Injectable } from "naily";
// 使用Injectable标记这是一个可以被注入的类
// 说人话就两个字:服务
@Injectable
export class AppService {
// 随便弄个方法
getData() {
return 200;
}
}
装饰器 | 说明 |
---|---|
RestController |
控制器 标识一个控制器必须要用这个 |
GetMapping |
标识 GET 方法装饰器 |
PostMapping |
标识 POST 方法装饰器 |
OptionsMapping |
标识 Options 方法装饰器 |
PutMapping |
标识 Put 方法装饰器 |
PatchMapping |
标识 Patch 方法装饰器 |
DeleteMapping |
标识 Delete 方法装饰器 |
RequestMapping |
匹配所有方法装饰器 |
RequestQuery |
获取 URL Query 装饰器 |
RequestParam |
获取 URL Param 装饰器 |
RequestBody |
获取 URL Body 装饰器 |
RequestIp |
获取 Ip 地址 装饰器 |
UseFilter |
使用错误过滤器 | |
参考test/main.filter.ts
。