Gatsby Image с Netlify CMS - Поле «изображение» не должно иметь выбор, так как тип «Строка» не имеет подполей - PullRequest
0 голосов
/ 15 мая 2019

Я создаю блог-сайт с Gatsby и использую Netlify CMS для управления своим контентом.Каждое сообщение в блоге имеет избранные изображения, указанные в frontmatter.

Но у меня есть некоторые проблемы с отображением этих изображений.Я продолжаю получать эту ошибку:

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

Post Frontmatter

---
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,
        },
      })
    })

  })
}

Ответы [ 2 ]

1 голос
/ 23 мая 2019

Я следовал этому руководству и преуспел в последних версиях 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 для изменения путей к файлам в ваших файлах разметки на пути, удобные для Gatsby, при использовании Netlify CMS для их редактирования».

В качестве альтернативы, если вы все еще предпочитаете использовать gatsby-remark -lative-images, вам нужно добавить

// gatsby-node.js
 const { fmImagesToRelative } = require('gatsby-remark-relative-images');

  exports.onCreateNode = ({ node }) => {
  fmImagesToRelative(node);
  };
0 голосов
/ 29 мая 2019

Попробуйте очистить кеш, используя:

gatsby clean

, а затем снова запустите сервер dev.

Я часто получаю эту ошибку случайно при работе с той же настройкой, что и вы.Очистка кеша и перезапуск обычно исправляют это.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...