Nest.js总结

参考Nest中文文档

启动项目

全局安装Nest.js脚手架,然后利用脚手架创建一个新项目指令如下所示:

bash 复制代码
$ npm i -g @nestjs/cli

$ nest new my-project-name

要使用 TypeScript 的 更严格 功能集创建新项目,请将 --strict 标志传递给 nest new 命令。

如下所示:nest new my-project-name --strict


项目文件

打开刚刚创建的项目文件,展开如下图所示:

├── my-test

│ ├── src

│ │ ├── app.controller.spec.ts

│ │ ├── app.controller.ts

│ │ ├── app.module.ts

│ │ ├── app.service.ts

│ │ └── main.ts

│ ├── test

│ │ ├── app.e2e-spec.ts

│ │ └── jest-e2e.json

│ ├── package.json

│ ├── README.md

│ ├── tsconfig.json

│ ├── ...

文件名 说明
app.controller.spec.ts 控制器的单元测试。
app.controller.ts 具有单一路由的基本控制器。
app.module.ts 应用的根模块。
app.service.ts 具有单一方法的基本服务。
main.ts 使用核心函数 NestFactory 创建 Nest 应用实例的应用入口文件。
test/* 模块的单元测试文件。

启动项目需要热更新的可以运行指令"start:dev"


创建一个控制器

bash 复制代码
$ nest g controller [name]

要使用 CLI 创建控制器,只需执行 $ nest g controller name 命令即可。

为了避免生成测试文件,你可以传递 --no-spec 标志,如下所示:nest g resource name --no-spec

javascript 复制代码
// cats.controller.ts
import { Controller, Get, Post } from '@nestjs/common';

@Controller('cats')
export class CatsController {
  @Post()
  create(): string {
    return 'This action adds a new cat';
  }

  @Get()
  findAll(): string {
    return 'This action returns all cats';
  }
}

Nest 为所有标准的 HTTP 方法提供装饰器:@Get()、@Post()、@Put()、@Delete()、@Patch()、@Options() 和 @Head()。

状态码
javascript 复制代码
// code.controller.ts
import { Controller, HttpCode, Post } from '@nestjs/common';

@Controller('code')
export class CodeController {
  @Post()
  @HttpCode(204)
  create() {
    return 'This action adds a new cat';
  }
}
重定向
javascript 复制代码
// redirect.controller.ts
import { Controller, Get, Redirect } from '@nestjs/common';

@Controller('redirect')
export class NofoundController {
  @Get()
  @Redirect('/')
  redirectToNewRoute() {}
}

使用数据库

本地安装一个MySQL,然后启动数据库服务,为了方便演示,使用phpStudy这个集成环境;

在项目安装访问数据库的模块:

bash 复制代码
$ npm install --save @nestjs/typeorm typeorm mysql2

安装过程完成后,我们可以将 TypeOrmModule 导入到根 AppModule 中。

javascript 复制代码
// app.module.ts
import { Module } from '@nestjs/common';
import { TypeOrmModule } from '@nestjs/typeorm';

@Module({
  imports: [
    TypeOrmModule.forRoot({
      type: 'mysql',
      host: 'localhost',
      port: 3306,
      username: 'root',
      password: 'root',
      database: 'test',
      entities: [],
      synchronize: true,
    }),
  ],
})
export class AppModule {}

以上链接数据库的方式可通过配置config,使用环境变量传递,如下所示:

bash 复制代码
DATABASE_USER=root
DATABASE_PASSWORD=root
实现一个新增接口
javascript 复制代码
import { Injectable } from '@nestjs/common';
import { CreateUserDto } from './dto/create-user.dto';
import { InjectRepository } from '@nestjs/typeorm';
import { User } from './entities/user.entity';
import { DataSource, Repository } from 'typeorm';

@Injectable()
export class UserService {
  constructor(
    @InjectRepository(User)
    private usersRepository: Repository<User>,
    private dataSource: DataSource,
  ) {}
  async create(createUserDto: CreateUserDto) {
    const { firstName, lastName, isActive } = createUserDto;
    try {
      await this.usersRepository
        .createQueryBuilder('user')
        .insert()
        .into(User)
        .values([{ firstName, lastName, isActive: !!Number(isActive) }])
        .execute();
      return {
        code: '200',
        data: '',
        msg: 'success',
      };
    } catch (error) {
      return {
        code: 'E500',
        data: JSON.stringify(error),
        msg: 'error',
      };
    }
  }
}
实现一个查询列表接口
javascript 复制代码
import { Injectable } from '@nestjs/common';
import { CreateUserDto } from './dto/create-user.dto';
import { InjectRepository } from '@nestjs/typeorm';
import { User } from './entities/user.entity';
import { DataSource, Repository } from 'typeorm';

@Injectable()
export class UserService {
  constructor(
    @InjectRepository(User)
    private usersRepository: Repository<User>,
    private dataSource: DataSource,
  ) {}
    async findAll(): Promise<UserList> {
		const data = await this.usersRepository
		  .createQueryBuilder('user')
		  .getMany();
		return {
		  data,
		  code: '200',
		  msg: 'success',
		};
	  }
  }
}

使用数据源查阅TypeORM

相关推荐
kyriewen2 分钟前
2026 年了,这 6 个 npm 包可以卸载了——浏览器原生 API 已经能替代
前端·javascript·npm
铁皮饭盒1 小时前
bun直接tsx,优雅!
javascript·后端
_柳青杨3 小时前
一文吃透 Node.js 事件循环:从原理到 Node 20+ 重大变更
javascript·后端
JieE21214 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
冬奇Lab16 小时前
AI Workflow 定义的四次演进:从 Markdown 到 JS 脚本,再到分布式多 Agent
javascript·人工智能·agent
一颗烂土豆1 天前
Meshopt 压缩深度解析,为什么它比 Draco 更快
前端·javascript·webgl
kyriewen1 天前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程
米丘1 天前
vite8 vite preview 命令做了什么?
node.js·vite
weedsfly1 天前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript
假如让我当三天老蒯1 天前
前端跨域解决方案(学习用)
前端·javascript·面试