首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    使用NestJs、GraphQL、TypeORM搭建后端服务

    TypeGraphQL是基于GraphQL重写的TypeScript版本,GraphQL的全称是:Graph Query Langue 图形化查询语言,是一个可由调用端定义API返回数据结构语言。...在我们过去常用的RestFul API中,我们可能在不同的业务中需要调用同一个接口,但是各自所需的数据有不同的情况下,服务端为了同时满足两个需求则提供了更多的字段,这样导致了一个两个业务请求到的数据都包含了自己不需要的字段...他们分别的作用是: imports:模块,用于添加App的子模块,可能是用户模块,可能是商品模块,也可能是支付模块。这里的类由@Module()装饰。...image.png 3.2、改造app.module.ts 从@nestjs/typeorm中引入NestJs与TypeORM连接模块*TypeOrmModule,然后传入一个Object作为与数据库链接的...4.3、声明pokemon模块,并引入到App中 到目前为止,我们以及创建好了TypeORM的entity实体,TypeGraphQL的ObjectType,现在我们先声明PokemonModule import

    6.7K10

    在NestJS应用程序中使用 Unleash 实现功能切换的指南

    前言 近年来,软件开发行业迅速发展,功能开关(Feature Toggle)成为了一种常见的开发实践。通过功能开关,可以在运行时动态地启用或禁用应用程序的特定功能,以提供更灵活的软件交付和配置管理。...下面是具体的操作步骤: 安装 NestJS NestJS 的安装非常简单,在安装之前需要确保你的机器中已经安装了 Node,然后执行以下命令即可在全局安装 NestJS。...这是初始化并注入到引导文件 main.ts 的文件。 在此文件中,注入所有控制器、服务器和其他模块,如下所示。...ConfigModule.forRoot() 将扫描根目录中的 .env 文件并将其加载到应用程序中。.../services/app.service'; @Module({ imports: [ConfigModule.forRoot()], controllers: [AppController

    25740

    Angular 路由配置(预加载配置,懒加载配置)

    (只有根模块才能设置bootstrap属性) }) 复制代码 3.懒加载说明 (1)RouterModule对象提供了两个静态的方法:forRoot()和forChild()来配置路由信息。...forRoot()//在主模块中定义主要的路由信息 forChild()``//应用在特性模块(子模块)中 (2)懒加载:loadChildren 此处并没有将对应的模块加入到AppModule中,而是通过...loadChildren的属性值由三部分组成: 需要导入Module的相对路径 #分隔符 导出模块类的名称 (3)预加载 在使用懒加载的情况下,路由第一次加载某个模块时,有时反应有延迟。...,这时就需要自定义预加载策略 A.自定义-5秒后加载所有模块 在app组建的同级新建一个custom-preloading-strategy.ts文件 import { Route } from '@angular...在app组建的同级新建一个selective-preloading-strategy.ts文件(需要在app-routing.module.ts中的providers注入,然后在路由中定义的data通过附加参数来设置是否预加载

    3.2K30

    Ionic 开发之 Ionic Storage 详解

    Ionic Storage 是一款基于 localForage 用于 Ionic 应用程序的简单 “键-值” 存储模块,支持 SQLite 开箱即用。...该工具可以根据平台自动选择最佳的存储引擎,而不用用户关系具体的使用细节。模块内存储引擎的默认选择顺序是 SQLite,IndexedDB,WebSQL 和 LocalStorage。...状态; get(key) —— 获取与给定键相关联的值,返回 Promise 对象; set(key, value) —— 设置给定键的值,返回 Promise 对象; remove(key) ——...它只是对 localForage 的 API 进行简单的封装,实际的存储功能还是交由 localForage 来完成,感兴趣的小伙伴可以研究一下。...实际的开发过程中,在数据存储时,我们可能还会涉及数据响应式、数据加密、数据压缩、数据迁移和备份,有上述需求的同学,可以了解一下 rxdb 这个库。

    3.9K10

    Angular 从入坑到挖坑 - 路由守卫连连看

    :是否允许通过延迟加载的方式加载某个模块 在添加了路由守卫之后,通过路由守卫返回的值,从而达到我们控制路由的目的 true:导航将会继续 false:导航将会中断,用户停留在当前的页面或者是跳转到指定的页面...中引入新创建的 CrisisModule、添加当前模块的路由配置) ng g module crisis --module app --routing 将 crisis-list、crisis-detail...组件全部移动到 crisis 模块下面,并在 CrisisModule 中添加对于 crisis-list、crisis-detail 组件的声明,同时将原来在 app.module.ts 中声明的组件代码移除...将当前模块的路由配置移动到专门的路由配置文件 crisis-routing.module.ts 中,并将 app-routing.module.ts 中相关的路由配置删除 import { NgModule...这里的问题与配置通配路由需要放到最后的原因相似,因为脚手架在帮我们将创建的模块导入到 app.module.ts 中时,是添加到整个数组的最后,同时因为我们已经将 crisis 模块的路由配置移动到专门的

    3.8K30

    Angular 启用预加载

    在使用路由延迟加载中,我们介绍了如何使用模块来拆分应用,在访问到这个模块的时候, Angular 加载这个模块。但这需要一点时间。在用户第一次点击的时候,会有一点延迟。...在上一节中,我们的根路由定义在 main.routing.ts,我们在 app.module.ts 中使用了根路由定义。 需要注意的是,Home 组件是提前加载的。我们将在系统启动之后渲染这个组件。...在 Angular 渲染 Home 组件之后,用户就可以与应用交互了,我们可以通过简单的配置在后台预加载其它模块。 启用预加载 我们在 forRoot 函数中,提供一个预加载的策略。...定制预加载策略 router 包中预定义了两个策略: 不预加载 NoPreloading 预加载所有模块 PreloadAllModules 5 秒之后加载模块 但是,您可以自己定义一个定制的策略。...加载指定模块 我们还可以在路由中定义附加的参数来指定哪些模块进行预加载,我们使用路由定义中的 data 来提供这个附加的数据。

    1.5K00

    Angular 2 + 折腾记 :(4)初步了解路由及使用

    路由相关的指令或者术语 :路由占位符,可以理解为渲染路由组件的区域,一个组件只能一个无命名,命名的可以多个 ng-content: 可以嵌套一个组件的内容在另外一个组件中...,具体可以去看API的改动 ---- 常规路由 import { NgModule } from '@angular/core'; import { Routes, RouterModule } from...; @NgModule({ // 注入到模块中,forChild只能用于子模块,forRoot只能用于跟模块 // forRoot有一个可选的配置参数,里面有四个选项 // enableTracing...,dashboard.module是文件名,#DashboardModule是里面到处的模块,必须紧跟才能正确识别 { path: 'base-data', loadChildren: 'app...(routes, { useHash: true }); // 上面这种写法只是把路由到处到一个变量,也就是要生效必须到相应的模块中引入(NgModule)中import进去复制代码 ---- 小技巧

    3K20

    一个Angular 5教程:一步一步指导实现你的第一个Angular 5应用程序

    因此,我们只需编写简单的代码即可获取我们的价值,并将其绑定到代码中的输入值和变量。...通过使用它,我们确保我们的数据流一旦发生this.alive错误就会停止发布新值,并且我们只需在该onDestroy组件的函数中设置该值。...两者都是不可变的,但第二个是基于第一个的,所以State我们创建一个新的State对象,而不是在我们的变异值上。...使用Angular的主要优点是获得一个完全集成的Web框架,该框架提供了自己的内置解决方案,用于构建组件,路由和使用远程API。 Angular模块如何工作? 模块将声明的范围分开。...这使我们可以为我们的应用程序构建多个独立模块,并为模块使用延迟加载。模块的目的是声明本模块中使用的所有内容,并允许Angular对其进行提前编译。 是基于角度MVC的?

    42.7K10

    Dotenv在nestjs中的使用

    Dotenv 是一个零依赖的模块,它能将环境变量中的变量从 .env 文件加载到 process.env 中。....env文件,我们只需在app.module.ts中引入ConfigModule,使用ConfigModule.forRoot()方法即可,然后ConfigService读取相关的配置变量。...数据库端口 DB_PORT=3306 // 数据库登录名 DB_USER=root // 数据库登录密码 DB_PASSWD=root // 数据库名字 DB_DATABASE=blog .env.prod中的是上线要用的数据库信息...,如果你的项目要上传到线上管理,为了安全性考虑,建议这个文件添加到.gitignore中。...直接调用configService的get方法,get方法第一个参数是环境变量属性,第二个参数为默认值。 以上便是在nestjs中使用dotenv的方法,希望对你有所帮助。

    17.1K42
    领券