带有Netlify CMS的盖茨比图片-字段“图片”不能选择,因为类型“字符串”没有子字段

时间:2019-05-15 19:41:26

标签: reactjs graphql gatsby netlify-cms

我正在与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,
        },
      })
    })

  })
}

4 个答案:

答案 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_folderpublic_folder。 但是,根据Netlify CMS文档:

如果未设置public_folder,则Netlify CMS的默认值与 media_folder,添加一个开头/(如果未包含)。

让Netlify CMS保留其默认功能,安装和配置插件后我的初始Netlify构建失败,并出现以下错误:

在Netlify CMS配置中错误缺少public_folder

在将public_folder手动添加到我的config.yml文件中之后,我没有任何其他问题。