一篇关于模式的文章
此功能允许你以类型安全的 Zod 模式形式获取模式描述,提供:
了解更多:https://zod.dev
要获取 Zod 模式,你需要:
cms-renderer 中的工具创建脚本apps/
web/
app/
page.tsx
scripts/
generated-schema.ts # 脚本文件
generated-schema.tsimport { fetchAllCustomSchemaFields, saveZodSchemaCode } from 'cms-renderer/lib/custom-schemas';
import { cmsConfig } from
export const cmsConfig = {
cmsUrl: process.env.NEXT_PUBLIC_CMS_API_URL,
apiKey: process.env.CMS_API_KEY,
websiteId: '...',
};
package.json 配置注意:如果你没有
tsconfig.json,请移除--tsconfig标志。
{
"name": "web",
"version": "0.1.0",
"type": "module",
"private": true,
"scripts": {
"generate-schemas": "tsx --tsconfig tsconfig.json scripts/generate-schemas.ts",
"...": "..."
},
"dependencies": {
"cms-renderer": "0.3.1",
"zod": "^4.3.6",
"...": "..."
},
"devDependencies": {
"tsx": "^4.21.0",
"object-hash": "^3.0.0",
"...": "..."
}
}
bun run generate-schemas
示例输出:
tsx --tsconfig tsconfig.json scripts/generate-schemas.ts
[generate-schemas] Done.
apps/
web/
app/
page.tsx
scripts/
generated-schema.ts
generated/
cms-schemas.ts # 生成的 Zod 模式
page.tsx 中的用法import type { PetFoodPost, SiteConfig } from '@/generated/cms-schemas';
import { petFoodPostSchema } from '@/generated/cms-schemas';
// 用于类型安全的解析
petFoodPostSchema.parse(obj);
bun run generate-schemas