React <StaticQuery>从不加载

时间:2020-07-10 14:55:56

标签: reactjs jsx gatsby prismic.io

堆栈:React / Gatsby + Prismic集成+ Netlify托管

问题:

Localhost browser when running develop

我尝试过的事情

  • 我在Github上找到了一个帖子,其中有人通过删除并恢复为以下代码来解决此问题:
    <LayoutContainer className="div">
                <Global styles={[globalStyles, typeStyles]} />
                <div className="Layout">
                    <Header />
                    <main className="Layout__content">
                        {children}
                    </main>
                    <Footer />
                </div>
            </LayoutContainer>
)
    
export const query = graphql`
        query SiteTitleQuery {
            site {
                siteMetadata {
                    title
                }
            }
        }
    `
  • 这有效。但是,如果您尝试构建或部署到Netlify,则会收到以下消息:
3:52:38 PM: error "gatsby-source-prismic-graphql" threw an error while running the sourceNodes lifecycle:
3:52:38 PM: Cannot use GraphQLDirective "@include" from another module or realm.
3:52:38 PM: Ensure that there is only one instance of "graphql" in the node_modules
3:52:38 PM: directory. If different versions of "graphql" are the dependencies of other
3:52:38 PM: relied on modules, use "resolutions" to ensure only one version is installed.
3:52:38 PM: https://yarnpkg.com/en/docs/selective-version-resolutions
3:52:38 PM: Duplicate "graphql" modules cannot be used at the same time since different
3:52:38 PM: versions may have different capabilities and behavior. The data from one
3:52:38 PM: version used in the function from another could produce confusing and
3:52:38 PM: spurious results.
3:52:38 PM:   74 |     if (!sdl) {
3:52:38 PM:   75 |       introspectionSchema = await introspectSchema(link);
3:52:38 PM: > 76 |       sdl = printSchema(introspectionSchema);
3:52:38 PM:      |             ^
3:52:38 PM:   77 |     } else {
3:52:38 PM:   78 |       introspectionSchema = buildSchema(sdl);
3:52:38 PM:   79 |     }
3:52:38 PM: 
3:52:38 PM: 
3:52:38 PM:   Error: Cannot use GraphQLDirective "@include" from another module or realm.
3:52:38 PM:   Ensure that there is only one instance of "graphql" in the node_modules
3:52:38 PM:   directory. If different versions of "graphql" are the dependencies of other
3:52:38 PM:   relied on modules, use "resolutions" to ensure only one version is installed.
3:52:38 PM:   https://yarnpkg.com/en/docs/selective-version-resolutions
3:52:38 PM:   Duplicate "graphql" modules cannot be used at the same time since different
3:52:38 PM:   versions may have different capabilities and behavior. The data from one
3:52:38 PM:   version used in the function from another could produce confusing and
3:52:38 PM:   spurious results.
3:52:38 PM:   
3:52:38 PM:   - Array.filter
3:52:38 PM:   
3:52:38 PM:   - gatsby-node.js:76 exports.sourceNodes
3:52:38 PM:     [repo]/[gatsby-source-prismic-graphql]/[gatsby-source-graphql-universal]/[ga    tsby-source-graphql]/gatsby-node.js:76:13
3:52:38 PM:   
3:52:38 PM:   - task_queues.js:97 processTicksAndRejections
3:52:38 PM:     internal/process/task_queues.js:97:5
3:52:38 PM:   
3:52:38 PM:   - api-runner-node.js:299 async runAPI
3:52:38 PM:     [repo]/[gatsby]/dist/utils/api-runner-node.js:299:16
3:52:38 PM:   
3:52:38 PM: 
3:52:38 PM: not finished source and transform nodes - 0.526s
3:52:38 PM: ​
3:52:38 PM: ┌─────────────────────────────┐
3:52:38 PM: │   "build.command" failed    │
3:52:38 PM: └─────────────────────────────┘

代码:

  • /components/Layout.jsx的当前状态如下
import React from "react";
import PropTypes from "prop-types";
import { graphql } from "gatsby";
import styled from "@emotion/styled";
import { Global } from "@emotion/core";
import globalStyles from 'styles/global';
import typeStyles from 'styles/typography';
import dimensions from "styles/dimensions";
import Footer from "components/Footer";
import Header from "components/Header";
import 'styles/fonts.scss';

const LayoutContainer = styled.div`
    max-width: ${dimensions.maxwidthDesktop}px;
    padding-left: ${dimensions.paddingHorizontalDesktop}em;
    padding-right: ${dimensions.paddingHorizontalDesktop}em;
    margin: 0 auto;

    @media(max-width: ${dimensions.maxwidthTablet}px) {
        padding-left: ${dimensions.paddingHorizontalTablet}em;
        padding-right: ${dimensions.paddingHorizontalTablet}em;
    }

    @media(max-width: ${dimensions.maxwidthMobile}px) {
        padding-left: ${dimensions.paddingHorizontalMobile}em;
        padding-right: ${dimensions.paddingHorizontalMobile}em;
    }

    .Layout__content {
        padding-bottom: 5em;
    }
`;

const Layout = ({ children }) => (
    <LayoutContainer className="div">
                <Global styles={[globalStyles, typeStyles]} />
                <div className="Layout">
                    <Header />
                    <main className="Layout__content">
                        {children}
                    </main>
                    <Footer />
                </div>
            </LayoutContainer>
)
    
export const query = graphql`
        query SiteTitleQuery {
            site {
                siteMetadata {
                    title
                }
            }
        }
    `
Layout.propTypes = {
    children: PropTypes.node.isRequired,
}

export default Layout;

非常感谢您的帮助

1 个答案:

答案 0 :(得分:0)

我在部署Prist Gatsby启动程序时也遇到了类似的问题。用Prismic分支替换gatsby-source-prismic-graphql程序包后,它开始工作了:

npm install --save @prismicio/gatsby-source-prismic-graphql

yarn add @prismicio/gatsby-source-prismic-graphql

...,并按照此处Phil的指示更新gatsby-config.js中的引用: https://community.prismic.io/t/error-with-module-gatsby-source-prismic-graphql/779/12