NestJS Logo
NestJS 中文文档
v10.0.0
  • 介绍
  • 快速上手
  • 控制器
  • 提供者
  • 模块
  • 中间件
  • 异常过滤器
  • 管道
  • 守卫
  • 拦截器
  • 自定义装饰器
  • 自定义提供者
  • 异步提供者
  • 动态模块
  • 依赖注入作用域
  • 循环依赖
  • 模块引用
  • 懒加载模块
  • 执行上下文
  • 生命周期事件
  • 发现服务
  • 跨平台无关性
  • 测试
迁移指南
API 参考
官方课程
  1. 文档
  2. GraphQL 支持
  3. 共享模型

生成 SDL
其他功能

共享模型(Sharing models)

注意

本章节仅适用于代码优先(code first)方式。

使用 TypeScript 作为项目后端的最大优势之一,就是能够通过一个通用的 TypeScript 包,在基于 TypeScript 的前端应用中复用相同的模型。

但这也带来了一个问题:使用代码优先方式创建的模型会被大量 GraphQL 相关的装饰器标记。这些装饰器在前端中并无意义,反而会影响性能。

使用模型 shim(model shim)

为了解决这个问题,NestJS 提供了一个「shim(垫片)」,允许你通过 webpack(或类似工具)的配置,将原有装饰器替换为无效代码。 要使用这个 shim,只需在 @nestjs/graphql 包和 shim 之间配置一个别名(alias)。

例如,在 webpack 中可以这样配置:

resolve: { // 参考:https://webpack.js.org/configuration/resolve/
  alias: {
      "@nestjs/graphql": path.resolve(__dirname, "../node_modules/@nestjs/graphql/dist/extra/graphql-model-shim")
  }
}
提示

TypeORM 包也有类似的 shim,可以在这里找到。