我正在与Gatsby建立一个博客站点,并且正在使用Netlify CMS管理我的内容。每篇博文都有一个在前题中指定的特色图片。
但是,在显示这些图像时遇到了一些问题。我不断收到此错误:
GraphQL Error Field "image" must not have a selection since type "String" has no subfields.
我尝试添加gatsby-remark-relative-images
来解决此问题,但这不起作用-我仍然遇到相同的错误。
关于如何解决此问题的任何想法?
目录结构
content
- articles
public
src
static
- admin
- images
帖子前沿
---
title: Post 1
image: img.png
---
gatsby-config.js
plugins: [
{
resolve: `gatsby-source-filesystem`,
options: {
name: `images`,
path: `${__dirname}/static/images`,
}
},
{
resolve: `gatsby-source-filesystem`,
options: {
name: `content`,
path: `${__dirname}/content`,
}
},
{
resolve: `gatsby-transformer-remark`,
options: {
plugins: [
{
resolve: `gatsby-remark-relative-images`,
},
{
resolve: `gatsby-remark-images`,
options: {
maxWidth: 590,
},
},
],
},
},
`gatsby-transformer-sharp`,
`gatsby-plugin-sharp`,
`gatsby-plugin-netlify-cms`,
`gatsby-plugin-sitemap`
]
gatsby-node.js
const path = require('path');
const { createFilePath } = require(`gatsby-source-filesystem`)
const { fmImagesToRelative } = require('gatsby-remark-relative-images');
exports.onCreateNode = ({ node, getNode, actions }) => {
const { createNodeField } = actions
fmImagesToRelative(node)
if (node.internal.type === `MarkdownRemark`) {
const slug = createFilePath({ node, getNode, basePath: `pages` })
createNodeField({
node,
name: `slug`,
value: slug,
})
}
}
exports.createPages = ({actions, graphql}) => {
const {createPage} = actions;
return graphql(`{
allMarkdownRemark {
edges {
node {
html
id
frontmatter {
title
date
templateKey
}
fields {
slug
}
}
}
}
}`)
.then(res => {
if (res.errors) {
return Promise.reject(res.errors);
}
res.data.allMarkdownRemark.edges.forEach(({node}) => {
createPage({
path: node.fields.slug,
component: path.resolve(
`src/templates/${String(node.frontmatter.templateKey)}.js`
),
context: {
// Data passed to context is available
// in page queries as GraphQL variables.
slug: node.fields.slug,
},
})
})
})
}
答案 0 :(得分:1)
我遵循了本教程,并获得了最新版本的Gatsby和netlify。 https://blog.rousek.name/2018/08/10/cool-image-loading-with-gatsbyjs-v2-and-netlify-cms-v2/。 基本上,您需要使用gatsby-plugin-netlify-cms-paths。 这将使Graphql能够查询图像,因为在Netlify上,图像字段是一种字符串类型。 插件作者的话说: “一个gatsby插件,可在使用Netlify CMS编辑时将Markdown文件中的文件路径更改为Gatsby友好路径。”
或者,如果您仍然喜欢使用gatsby-remark-relative-images,则需要添加
// gatsby-node.js
const { fmImagesToRelative } = require('gatsby-remark-relative-images');
exports.onCreateNode = ({ node }) => {
fmImagesToRelative(node);
};
答案 1 :(得分:1)
虽然@issydennis的回答可能有所帮助。如果您在内容定义中设置的图像与实际图像不匹配,请确保仔细检查图像路径和名称,盖茨比会提示该错误,而不是找不到图像。
答案 2 :(得分:0)
尝试使用以下方法清除缓存:
gatsby clean
然后再次运行开发服务器。
在使用与您相同的设置时,我经常会随机收到此错误。通常清除缓存并重新启动即可解决。
答案 3 :(得分:0)
最容易直接访问gatsby-plugin-netlify-cms-paths
的盖茨比文档
https://www.gatsbyjs.org/packages/gatsby-plugin-netlify-cms-paths/
一个警告,...
您的config.yml
文件应同时指定media_folder
和public_folder
。
但是,根据Netlify CMS文档:
如果未设置public_folder,则Netlify CMS的默认值与 media_folder,添加一个开头/(如果未包含)。
让Netlify CMS保留其默认功能,安装和配置插件后我的初始Netlify构建失败,并出现以下错误:
在Netlify CMS配置中错误缺少public_folder
在将public_folder
手动添加到我的config.yml
文件中之后,我没有任何其他问题。