我正在尝试为sanity.io
中的文档自定义prview部分。为此,我创建了以下文档:
export default {
name: 'news',
type: 'document',
title: 'News',
fields: [
{
name: 'title',
title: 'Title',
type: 'string',
},
...
{
name: 'author',
title: 'Author',
type: 'string',
},
...
],
preview: {
select: {
title: 'title',
subtitle: 'author',
}
}
}
这完全符合我在Studio中的要求。预览窗格中的title
部分显示文档的标题,而subtitle
部分显示作者的姓名。
但是,如果我尝试使用author
来修改prepare
的输出,那么它将不再起作用。例如,看一下同一文档的以下变体:
export default {
name: 'news',
type: 'document',
title: 'News',
fields: [
{
name: 'title',
title: 'Title',
type: 'string',
},
...
{
name: 'author',
title: 'Author',
type: 'string',
},
...
],
preview: {
select: {
title: 'title',
author: 'author',
}
},
prepare(selection) {
const { author } = selection
return {
...selection,
subtitle: author && `${author} is the author`
}
}
}
呈现title
预览字段,但subtitle
部分中未显示任何内容。但是,据我了解-这应该可行。我想知道为什么不这样做。
有什么想法吗?
答案 0 :(得分:3)
prepare
实际上是在预览中调用的功能。您将其作为根对象的单独字段。像这样在preview
内部移动准备:
preview: {
select: {
title: 'title',
author: 'author'
},
prepare(selection) {
const { author } = selection
return {
...selection,
subtitle: author && `${author} is the author`
}
}
}