0

我有一个读取如下内容的架构:页面(文档)有一个项目数组(对象);每个 Item 可以有一个 Post(文档);每个帖子都有几个标签(文档)。

我已经完成了大部分的钻取工作,但由于某种原因,我无法完全解决标签上的连接问题。这是我的架构的简要介绍:


{ name: 'page',
  type: 'document',
  fields: [
    { name: 'title', type: 'string' },
    { name: 'slug', type: 'slug' },
    { name: 'items', type: 'array',
      of: [
        { type: 'itemImage' }, /* and a couple others */
      ],
    },
  ],
},

{ name: 'itemImage',
  type: 'object',
  fields: [
    { name: 'image',
      title: 'Image',
      type: 'image',
      validation: Rule => Rule.required(),
    },
    { name: 'post',
      type: 'reference',
      to: [
        { type: 'post' },
      ],
    },
  ]
},

{ name: 'post',
  type: 'document',
  title: 'Post',
  fields: [
    { name: 'title',
      type: 'string',
    },
    { name: 'tags',
      type: 'array',
      of: [
        { type: 'reference', to: [{type: 'tag'}] },
      ]
    },
  ],
},

{ name: 'tag',
  type: 'document',
  fields: [
    { name: 'tag', type: 'string' },
  ],
},

这是我的工作查询......</p>

*[_type == "page" && slug.current == "home"] {
  'slug': slug.current, 
  title, 
  'gridItems': items[] {
    'src': image.asset->url,
    'title': post->title,
    'postLink': post->slug.current,
  }
}[0]

...所以我已经弄清楚如何查询对象数组以及如何查询引用文档,但我似乎无法桥接查询引用文档数组。有什么线索吗?

4

1 回答 1

0

知道了

*[_type == "page" && slug.current == "home"] {
  'slug': slug.current, 
  title, 
  'gridItems': items[] {
    'src': image.asset->url,
    'title': post->title,
    'postLink': post->slug.current,
    'tags': post->tags[]->{tag}
  }
}[0]
于 2020-10-01T19:32:06.350 回答