为了账号安全,请及时绑定邮箱和手机立即绑定

使用 Gatsby 时在何处记录数据以及如何将数据导入 gatsby.config.js

使用 Gatsby 时在何处记录数据以及如何将数据导入 gatsby.config.js

LEATH 2022-07-08 18:33:29
我跟着Gatsby Docs 关于 Gatsby中的数据,他们向我展示了如何在其中的 siteMetadata 块中创建 graphql 变量gatsby.config.jsmodule.exports = {  siteMetadata: {    title: `Title from siteMetadata`,  },  plugins: [    `gatsby-plugin-emotion`,    {      resolve: `gatsby-plugin-typography`,      options: {        pathToConfigModule: `src/utils/typography`,      },    },  ],}然后可以使用 graphql 查询访问它import React from "react"import { graphql } from "gatsby"import Layout from "../components/layout"export default ({ data }) => (  <Layout>    <h1>About {data.site.siteMetadata.title}</h1>    <p>      We're the only site running on your computer dedicated to showing the best      photos and videos of pandas eating lots of food.    </p>  </Layout>)export const query = graphql`  query {    site {      siteMetadata {        title      }    }  }`我想将我的网络应用程序中的所有数据与其余代码分开,并且全部包含在一个地方,例如我可能有一个看起来像的文件navLinks = ["Home", "About", "Contact"]homePageIntro = "Hello! Thank you for visiting my website"logo = 'https://aws.amazon.com/mys3.logo'contactPhoto = 'https://aws.amazon.com/mys3.logo'aboutPageFirstPar = 'This is the first paragraph on the about page'aboutPageSecondPar = 'This is the Second paragraph on the about page'或者将我的文本和链接分开到单独的文件中可能是更好的做法?我只是觉得将所有数据变量插入到 siteMetadata 可能不是最好的方法,但也许我错了?
查看完整描述

1 回答

?
慕婉清6462132

TA贡献1804条经验 获得超2个赞

您可以将数据移动到单个 JSON 文件中,然后用于gatsby-transformer-json将其放入 graphql。这样,您可以使用 graphql 查询访问您的数据。

PS。您也可以使用useStaticQuery挂钩。

在此处阅读更多信息:https ://www.gatsbyjs.org/packages/gatsby-transformer-json/


查看完整回答
反对 回复 2022-07-08
  • 1 回答
  • 0 关注
  • 144 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信