以类型安全为目标的 nodejs 全栈 monorepo 模版

仓库地址:github.com/dobble11/pr...

这是以类型安全为目标的全栈 monorepo 模版,采用 GraphQL 作为数据交换层,并通过 @graphql-codegen/cli 将编写的查询 gql 生成前端请求 Hook 代码。

数据库访问由 ORM prisma 驱动,通过 pothos 构建 code-first GraphQL schema,结合 pothos prisma 插件实现类型从数据库模型映射到 GraphQL,再映射到前端查询 Hook,保证了整个链路类型的安全。

预览

此模版包含用户登录并查询 User 表的最小 DEMO 代码

项目结构

  • apps/client: 客户端根目录
  • apps/server: 服务端根目录
  • packages/eslint-config-custom: ESLint 基础配置
  • packages/tsconfig: TypeScript 配置,包含服务端、React 应用、React Library 配置

主要技术栈

客户端

服务端

仓库

  • turbo - monorepo 构建系统
  • pnpm - 包管理器

开始

安装依赖

sh 复制代码
pnpm i

配置服务端环境变量

新建 apps/server/.env 文件,输入以下内容

env 复制代码
SERVER_PORT=4010
DATABASE_URL=postgresql://postgres:postgres@localhost:5432/prisma-gql?schema=public

# 通过 docker compose 启动时需要配置
PG_USER=postgres
PG_PASSWORD=postgres

以上数据库信息可以根据自身情况进行配置

准备服务端依赖服务

如果没有 postgres 服务,可以单独启动或者使用 docker compose 启动

sh 复制代码
# 单独启动
docker run --name postgres -p 5432:5432 -e POSTGRES_PASSWORD=postgres -d postgres

# 使用 docker compose
cd apps/server
docker compose up -d

创建数据库并生成访问代码

sh 复制代码
cd apps/server
pnpm prisma db push

# 初始化用户
pnpm tsx ./scripts/seed.ts

启动服务

sh 复制代码
# 仓库根目录下
pnpm dev
相关推荐
c***69302 小时前
node.js下载、安装、设置国内镜像源(永久)(Windows11)
node.js
全栈前端老曹2 小时前
【包管理】npm init 项目名后底层发生了什么的完整逻辑
前端·javascript·npm·node.js·json·包管理·底层原理
callJJ3 小时前
MCP配置与实战:深入理解现代开发工具链
javascript·node.js·vue·mcp·windsurf
程序员爱钓鱼3 小时前
Node.js 编程实战:测试与调试 —— 日志与监控方案
前端·后端·node.js
雪域迷影5 小时前
Node.js中使用node-redis库连接redis服务端并存储数据
数据库·redis·node.js
winfredzhang6 小时前
从零构建:基于 Node.js 的全栈视频资料管理系统开发实录
css·node.js·html·音视频·js·收藏,搜索,缩略图
遗憾随她而去.6 小时前
Webpack 面试题
前端·webpack·node.js
全栈前端老曹1 天前
【包管理】read-pkg-up 快速上手教程 - 读取最近的 package.json 文件
前端·javascript·npm·node.js·json·nrm·package.json
水冗水孚1 天前
告别黑盒!手写Windows版简易NodeMON,学习文件监听代码修改与进程服务重启知识
node.js·express
程序员爱钓鱼1 天前
Node.js 编程实战:测试与调试 —— 调试技巧与性能分析
前端·后端·node.js