首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >访问当前页面的前沿信息-- Gatsby/React

访问当前页面的前沿信息-- Gatsby/React
EN

Stack Overflow用户
提问于 2020-02-08 01:57:01
回答 3查看 680关注 0票数 0

是否可以通过默认布局访问当前页的前端。

使用graphql,是否有根据页面的url筛选查询的选项?

.MDX锋前物

代码语言:javascript
复制
---
Title: 'About Us'
---

gatsby-config.js

代码语言:javascript
复制
{
    resolve: 'gatsby-plugin-mdx',
    options: {
        defaultLayouts: {
            pages: require.resolve('./src/layouts/default.js'),
        },
    },
}

default.js

代码语言:javascript
复制
<>
    <header>?? Insert MDX Title ??</header>
    <main></main>
    <footer></footer>
</>
EN

回答 3

Stack Overflow用户

发布于 2020-09-24 20:54:27

即使您使用默认MDX模板从./src/pages/自动生成页面,仍然需要将以下内容添加到gatsby-config.js中的plugins部分

代码语言:javascript
复制
{
  resolve: `gatsby-source-filesystem`,
  options: {
    name: `pages`,
    path: `${__dirname}/src/pages/`,
  }
}

现在,您可以使用pageContext.frontmatter访问前端,如文档中提到的那样:

代码语言:javascript
复制
import React from 'react'
import Layout from './layout'

export default ({ children, pageContext }) => {

  return (
    <Layout>
      <h1>{pageContext.frontmatter.title}</h1>
      <article>{children}</article>
    </Layout>
  )
}
票数 2
EN

Stack Overflow用户

发布于 2020-02-08 03:52:24

是的有。一种方法是运行gatsby develop并对被运行的GraphiQL实例运行查询。我的.mdx文件中有标题,它可以通过allMdxmdx模式获得。Gatsby文档这里解释了如何使用查询设置组件。

代码语言:javascript
复制
{
  allMdx {
    edges {
      node {
        frontmatter {
          title
        }
      }
    }
  }
  mdx {
    frontmatter {
      title
    }
  }
}
票数 0
EN

Stack Overflow用户

发布于 2020-02-08 05:22:19

MDX前端将与children一起自动传递到父上下文中。

{props.pageContext.frontmatter.Title}

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60123284

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档