以类型安全为目标的 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
相关推荐
垣宇2 小时前
Vite 和 Webpack 的区别和选择
前端·webpack·node.js
爱吃南瓜的北瓜3 小时前
npm install 卡在“sill idealTree buildDeps“
前端·npm·node.js
翻滚吧键盘3 小时前
npm使用了代理,但是代理软件已经关闭导致创建失败
前端·npm·node.js
浪九天4 小时前
node.js的版本管理
node.js
浪九天6 小时前
node.js的常用指令
node.js
浪九天8 小时前
Vue 不同大版本与 Node.js 版本匹配的详细参数
前端·vue.js·node.js
小纯洁w19 小时前
Webpack 的 require.context 和 Vite 的 import.meta.glob 的详细介绍和使用
前端·webpack·node.js
熬夜不洗澡21 小时前
Node.js中不支持require和import两种导入模块的混用
node.js
bubusa~>_<21 小时前
解决npm install 出现error,比如:ERR_SSL_CIPHER_OPERATION_FAILED
前端·npm·node.js
天下皆白_唯我独黑1 天前
npm 安装扩展遇到证书失效解决方案
前端·npm·node.js