React Node.js 和 Prisma 构建全栈框架

特点

  • 快速入门:由于其表现力强,您可以使用很少的简洁、一致的声明性代码从头开始创建和部署生产就绪的 Web 应用程序。
  • 无样板代码:通过抽象出复杂的全栈功能,可以减少样板代码。这意味着需要维护和理解的代码更少!这也意味着更容易升级。
  • 无锁定:您可以将此框架上的应用程序部署在任何您喜欢的地方。不存在特定提供商的锁定,您可以完全控制代码。
  • 全栈身份验证
  • RPC(客户端<->服务器)
  • 简单部署
  • 作业
  • 电子邮件发送
  • 全栈类型安全

代码片段

javascript 复制代码
app todoApp {
  title: "ToDo App",  // visible in the browser tab
  auth: { // full-stack auth out-of-the-box
    userEntity: User, methods: { email: {...} }
  }
}

route RootRoute { path: "/", to: MainPage }
page MainPage {
  authRequired: true, // Limit access to logged-in users.
  component: import Main from "@client/Main.tsx" // Your React code.
}

query getTasks {
  fn: import { getTasks } from "@server/tasks.js", // Your Node.js code.
  entities: [Task] // Automatic cache invalidation.
}

entity Task {=psl  // Your Prisma data model.
    id          Int     @id @default(autoincrement())
    description String
    isDone      Boolean @default(false)
psl=}

在配置中定义您的应用程序并获取:

  • 使用 Auth UI 组件登录和注册,
  • 全栈式安全
  • 电子邮件发送
  • 异步处理作业
  • React Query 支持数据获取
  • 安全最佳实践

假设您想要构建一个 Web 应用程序,允许用户创建和分享他们最喜欢的食谱。

让我们从此件开始:它是应用程序的中心文件,您可以在其中从高层描述应用程序。

让我们给我们的应用程序一个标题,然后立即通过用户名和密码打开全栈身份验证:

javascript 复制代码
app RecipeApp {
  title: "My Recipes",
  auth: {
    methods: { usernameAndPassword: {} },
    onAuthFailedRedirectTo: "/login",
    userEntity: User
  }
}

然后让我们为您的食谱添加数据模型。我们希望用户和用户可以拥有食谱:

javacript 复制代码
...

entity User {=psl  // Data models are defined using Prisma Schema Language.
  id          Int @id @default(autoincrement())
  username    String @unique
  password    String
  recipes     Recipe[]
psl=}

entity Recipe {=psl
  id          Int @id @default(autoincrement())
  title       String
  description String?
  userId      Int
  user        User @relation(fields: [userId], references: [id])
psl=}

框架链接

参阅 - 亚图跨际
相关推荐
AAA阿giao3 小时前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
摘星编程16 小时前
React Native鸿蒙版:Image图片占位符
react native·react.js·harmonyos
飞羽殇情21 小时前
基于React Native鸿蒙跨平台开发构建完整电商预售系统数据模型,完成参与预售、支付尾款、商品信息展示等
react native·react.js·华为·harmonyos
摘星编程21 小时前
React Native + OpenHarmony:ImageSVG图片渲染
javascript·react native·react.js
摘星编程1 天前
OpenHarmony + RN:Text文本书写模式
javascript·react native·react.js
xixixin_1 天前
【React】中 Body 类限定法:优雅覆盖挂载到 body 的组件样式
前端·javascript·react.js
摘星编程1 天前
用React Native开发OpenHarmony应用:Image网络图片加载
javascript·react native·react.js
摘星编程1 天前
OpenHarmony环境下React Native:ImageBase64图片显示
javascript·react native·react.js
毕设源码-朱学姐1 天前
【开题答辩全过程】以 基于Node.js的书籍分享平台设计与实现为例,包含答辩的问题和答案
node.js
摘星编程1 天前
React Native鸿蒙:Image本地图片显示
javascript·react native·react.js