Velite 模式
要在 Velite 中使用 Zod,请从 'velite' 导入 z 实用工具。这是对 Zod 库的重新导出,支持 Zod 的所有功能。
查阅 Zod 文档 获取关于 Zod 工作原理及可用功能的完整说明。
import { z } from 'velite'
// `z` 是 Zod 的重新导出此外,Velite 扩展了 Zod 模式,添加了构建内容模型时一些常用功能,你可以从 'velite' 导入 s 来使用这些扩展模式。
import { s } from 'velite'
// `s` 在 Zod 基础上扩展了一些自定义模式,
// `s` 也包含了 zod 的所有成员,因此你可以将 `s` 当作 `z` 来使用s.isodate()
string => string
将日期字符串格式化为 ISO 日期字符串。
date: s.isodate()
// 情况 1. 有效的日期字符串
// '2017-01-01' => '2017-01-01T00:00:00.000Z'
// 情况 2. 有效的日期时间字符串
// '2017-01-01 10:10:10' => '2017-01-01T10:10:10.000Z'
// 情况 3. 无效的日期字符串
// 'foo bar invalid' => 报错 'Invalid date string's.unique(by)
string => string
验证集合中的值是否唯一。
name: s.unique('taxonomies')
// 情况 1. 唯一值
// 'foo' => 'foo'
// 情况 2. 非唯一值(在所有通过 'taxonomies' 标识为唯一的集合中)
// 'foo' => 报错 'Already exists'参数
by: 唯一标识符
- 类型:
string - 默认值:
'global'
s.slug(by, reserved)
string => string
基于 s.unique(),在集合中保持唯一,不允许使用保留值,并验证 slug 格式。
slug: s.slug('taxonomies', ['admin', 'login'])
// 情况 1. 唯一的 slug 值
// 'hello-world' => 'hello-world'
// 情况 2. 非唯一值(在所有通过 'taxonomies' 标识为唯一的集合中)
// 'hello-world' => 报错 'Slug already exists'
// 情况 3. 保留的 slug 值
// 'admin' => 报错 'Slug is reserved'
// 情况 4. 无效的 slug 值
// 'Hello World' => 报错 'Invalid slug'参数
by: 唯一标识符
- 类型:
string - 默认值:
'global'
reserved: 保留值
- 类型:
string[] - 默认值:
[]
s.file(options)
string => string
相对于此文件的文件路径,将文件复制到 config.output.assets 目录并返回公共 URL。
avatar: s.file()
// 情况 1. 相对路径
// 'avatar.png' => '/static/avatar-34kjfdsi.png'
// 情况 2. 不存在的文件
// 'not-exists.png' => 报错 'File not exists'
// 情况 3. 绝对路径或完整 URL(如果允许)
// '/icon.png' => '/icon.png'
// 'https://zce.me/logo.png' => 'https://zce.me/logo.png'参数
options.allowNonRelativePath:
是否允许非相对路径。如果为 true,值将被直接返回;如果为 false,值将被作为相对路径处理。
- 类型:
boolean - 默认值:
true
s.image(options)
string => Image
相对于此文件的图像路径,类似 s.file(),将文件复制到 config.output.assets 目录并返回 Image(包含元数据的图像对象)。
avatar: s.image()
// 情况 1. 相对路径
// 'avatar.png' => {
// src: '/static/avatar-34kjfdsi.png',
// width: 100,
// height: 100,
// blurDataURL: '',
// blurWidth: 8,
// blurHeight: 8
// }
// 情况 2. 不存在的文件
// 'not-exists.png' => 报错 'File not exists'
// 情况 3. 绝对路径或完整 URL(如果允许)
// '/icon.png' => { src: '/icon.png', width: 0, height: 0, blurDataURL: '', blurWidth: 0, blurHeight: 0 }
// 'https://zce.me/logo.png' => { src: 'https://zce.me/logo.png', width: 0, height: 0, blurDataURL: '', blurWidth: 0, blurHeight: 0 }参数
options.absoluteRoot:
绝对路径的根路径。如果提供,值将被作为绝对路径处理。
- 类型:
string - 默认值:
undefined
类型
/**
* 包含元数据和模糊图像的图像对象
*/
interface Image {
/**
* 图像的公共 URL
*/
src: string
/**
* 图像宽度
*/
width: number
/**
* 图像高度
*/
height: number
/**
* 图像的模糊数据 URL
*/
blurDataURL: string
/**
* 模糊图像宽度
*/
blurWidth: number
/**
* 模糊图像高度
*/
blurHeight: number
}s.metadata()
string => Metadata
将输入或文档正文解析为 Markdown 内容并返回 Metadata。
目前仅支持 readingTime(阅读时间)和 wordCount(字数统计)。
metadata: s.metadata()
// 文档正文 => { readingTime: 2, wordCount: 100 }类型
/**
* 文档元数据。
*/
interface Metadata {
/**
* 阅读时间(分钟)。
*/
readingTime: number
/**
* 字数统计。
*/
wordCount: number
}s.excerpt(options)
string => string
将输入或文档正文解析为 Markdown 内容并返回摘要文本。
excerpt: s.excerpt()
// 文档正文 => 摘要文本参数
options: 摘要选项
options.length:
摘要长度。
- 类型:
number - 默认值:
260
s.markdown(options)
string => string
将输入或文档正文解析为 Markdown 内容并返回 HTML 内容。有关更多信息,请参阅 Markdown 支持。
content: s.markdown()
// => HTML 内容参数
options: Markdown 选项
- 类型:
MarkdownOptions,参见 MarkdownOptions - 默认值:
{ gfm: true, removeComments: true, copyLinkedFiles: true }
s.mdx(options)
string => string
将输入或文档正文解析为 MDX 内容并返回组件函数体。有关更多信息,请参阅 MDX 支持。
code: s.mdx()
// => 函数体参数
options: MDX 选项
- 类型:
MdxOptions,参见 MdxOptions - 默认值:
{ gfm: true, removeComments: true, copyLinkedFiles: true }
s.raw()
string => string
返回原始文档正文。
code: s.raw()
// => 原始文档正文s.toc(options)
string => TocEntry[] | TocTree
将输入或文档正文解析为 Markdown 内容并返回 目录。
toc: s.toc()
// 文档正文 => 目录参数
options: 目录选项
- 类型:
TocOptions,参见 选项
options.original:
保留原始目录。
- 类型:
boolean - 默认值:
false
类型
interface TocEntry {
/**
* 目录项标题
*/
title: string
/**
* 可以用来访问内容的
* URL
*/
url: string
/**
* 嵌套项目
*/
items: TocEntry[]
}
/**
* 目录树
*/
export interface TocTree {
/**
* 目录标题后紧接着的节点索引,如果未找到标题则为 `-1`,
* 如果未提供 `heading` 则为 `undefined`。
*/
index?: number
/**
* `heading` 之后第一个不属于其部分的节点索引,
* 如果未找到标题则为 `-1`,如果未提供 `heading` 则为 `undefined`,
* 如果 `heading` 和目录中第一个标题之间没有节点,则与 `index` 相同。
*/
endIndex?: number
/**
* 表示生成目录的列表,如果无法创建目录(可能是因为未找到标题
* 或未找到后续标题)则为 `undefined`。
*/
map?: List
}有关 Result 和 Options 的更多信息,请参阅 mdast-util-toc。
s.path(options)
=> string
基于文件路径获取扁平化路径。
path: s.path()
// => 扁平化路径,例如:'posts/2021-01-01-hello-world'参数
options: 扁平化选项
- 类型:
PathOptions
options.removeIndex:
从路径中移除 index。
- 类型:
boolean - 默认值:
true
Zod 原始类型
此外,所有 Zod 内置模式都可以正常使用,例如:
title: s.string().mix(3).max(100)
description: s.string().optional()
featured: s.boolean().default(false)你可以查阅 https://zod.dev 获取完整的支持文档。
定义自定义模式
有关自定义模式的更多信息,请参阅 自定义模式。