做了一个nest.js prisma模块,让prisma支持切面编程的精髓:监听器

开头先上正菜。安装方法:

bash 复制代码
pnpm i @nailyjs.nest.modules/prisma

没装Prisma的请先装:

bash 复制代码
pnpm i prisma @prisma/client

这俩是必须滴。

使用

和其他三方nest模块一样,参照README.md先从@nailyjs.nest.modules/prisma中导入PrismaModule到你的根模块中。

typescript 复制代码
import { Module } from '@nestjs/common';
import { PrismaModule } from '@nailyjs.nest.modules/prisma';

@Module({
  imports: [
    // 导入Prisma模块。如果不注册任何监听器,可以这么导入。
    PrismaModule.forRoot(),
  ],
})
export class AppModule {}

然后在任何地方都可以注入PrismaServicePrismaClient两个类了。

PrismaClient@prisma/client包导入,监听器不会监听到PrismaClient发出的事件;PrismaService的基类就是PrismaClient,在PrismaClient的基础上实现了监听器的功能。

一般情况下,请使用PrismaService; 除非有特殊的需求,不想让监听器监听到,那就可以使用PrismaClient

PrismaClient本来是不能被nest.js注入的,但是由于PrismaModule.forRoot()了,此时PrismaClient就是可以被注入的类了。可以很轻松地使用这俩类😜

撰写Service

typescript 复制代码
import { Injectable } from '@nestjs/common';
import { PrismaService } from '@nailyjs.nest.modules/prisma';

@Injectable()
export class AppService {
  constructor(
      // 这是能被监听器监听到的
      private readonly prismaService: PrismaService,
      // 这是不能的
      private readonly prismaClient: PrismaClient
  ) {}

  async findMany() {
    return this.prismaService.user.findMany();
  }
}

一个示例Subscriber

import语句我就不写了,懒得弄。看得懂就行。

typescript 复制代码
@Injectable()
export class PrismaListener {
  /**
   * 假设您有一个名为`user`的prisma模型,可以在这里注册一个监听器,监听`findMany`事件。
   * BeforeListen顾名思义,就是在`findMany`方法执行之前执行的方法。
   */
  @BeforeListen('user', 'findMany')
  public async beforeFindMany() {
    console.log('before findMany');
  }

  /**
   * AfterListen顾名思义,就是在`findMany`方法执行之后执行的方法。
   */
  @AfterListen('user', 'findMany')
  public async afterFindMany() {
    console.log('after findMany');
  }
}

BeforeListenAfterListen@nailyjs.nest.modules/prisma包导入。

写好了之后,还要注册到forRoot

typescript 复制代码
@Module({
  imports: [
    PrismaModule.forRoot({
        subscribers: [PrismaListener]
    }),
  ],
})
export class AppModule {}

然后每次调用user表里的findMany方法时,都会先依次触发PrismaListener里的beforeFindMany方法,然后结束后再触发afterFindMany方法。

这样,就实现了切面的逻辑分离了。

这个包于2024年2月5日新鲜出炉,想上生产的都先等会()说不定有bug呢(自己玩一玩还是不错滴

相关推荐
Q_Q5110082851 天前
python+django/flask的图书馆管理系统vue
spring boot·python·django·flask·node.js·php
Q_Q5110082851 天前
python+django/flask的美食交流宣传系统vue
spring boot·python·pycharm·django·flask·node.js·php
Q_Q5110082851 天前
python+django/flask+vue的基层智能化人员调度系统pycharm-计算机毕业设计
spring boot·python·pycharm·django·flask·node.js
jenchoi4131 天前
软件供应链npm/pypi投毒预警情报【2025-11-09】
前端·安全·web安全·网络安全·npm·node.js
百***41662 天前
node.js+npm的环境配置以及添加镜像(保姆级教程)
arcgis·npm·node.js
百***41662 天前
2024最新版Node.js下载安装及环境配置教程【保姆级】
node.js
Q_Q19632884752 天前
python+django/flask的医院财务管理系统
spring boot·python·django·flask·node.js
cmdyu_2 天前
修复mac系统下node22安装模块报fatal error: ‘memory‘ file not found错误的问题
macos·npm·node.js
nvvas2 天前
npm : 无法加载文件 D:\nvm\nodejs\npm.ps1,因为在此系统上禁止运行脚本问题解决
前端·npm·node.js
阿珊和她的猫2 天前
Webpack Loader 和 Plugin 实现原理详解
前端·webpack·node.js