reactjs - 无法使用 graphQL 和 createPages 在 Gatsby 中进行转换

标签 reactjs transition gatsby reach-router

我对 gatsby-wordpress-starter ( https://www.gatsbyjs.org/starters/?c=Wordpress ) 进行了 git 克隆

在不做任何更改的情况下,我添加了姿势: (https://popmotion.io/pose/examples/route-transitions-reach-router/)

按照上述网址中的说明,我将 Components/layout.js 文件更改为以下内容(略有不同,因为页面路径没有像示例那样硬编码到布局中):

import React from 'react'
import ReactDOM from 'react-dom';
import { Router, Link, Location } from '@reach/router';
import Helmet from 'react-helmet'

import Navbar from '../components/Navbar'
import Page from '../templates/page'
import './all.sass'
import posed, { PoseGroup } from 'react-pose';

const RouteContainer = posed.div({
  enter: { opacity: 1, delay: 300, beforeChildren: 300 },
  exit: { opacity: 0 }
});

const PosedRouter = ({ children }) => (
<Location>
    {({ location }) => (      <PoseGroup>
        <RouteContainer key={location.key}>
          <Router location={location}>{children}</Router>
        </RouteContainer>

      </PoseGroup>

)}
  </Location>
);


const TemplateWrapper = ({children}) => (
<div>

    <Helmet title="Home | Gatsby + Netlify CMS" />
    <Navbar />

        <PosedRouter/>
        {console.log(location)}
</div>
)

export default TemplateWrapper

当我运行此命令时,我得到: Uncaught TypeError: Cannot read property 'map' of undefined

如果我展开“location”的console.log,那里就没有“key”

除此之外,我还尝试安装官方的 gatsby 转换插件,但这也无法正常工作。它执行进入转换,但不执行退出转换。它确实会触发退出的转换,但要等到页面内容更改后才会触发。

最佳答案

我建议使用另一种方法,这是我一直用来创建页面过渡(淡入、淡出等)的方法:使用 gatsby-plugin-transition-link 。我不确定您尝试过哪一个,但是这个有效并且具有更清晰和更语义化的效果 方法。

它允许您创建自定义动画或使用一些默认或预定义的动画,您可以查看其演示站点 here其中有一些转换的示例。

对于预定义的过渡(最简单的方法),您只需要导入 de 组件并像这样使用它:

import AniLink from "gatsby-plugin-transition-link/AniLink"

<AniLink paintDrip to="page-2">
  Go to Page 2
</AniLink>

对于自定义转场,需要定义de entry和exit effect,如:

<TransitionLink
  exit={{
    length: length,
    trigger: ({ exit, node }) =>
      this.someCustomDefinedAnimation({ exit, node, direction: "out" }),
  }}
  entry={{
    length: 0,
    trigger: ({ exit, node }) =>
      this.someCustomDefinedAnimation({ exit, node, direction: "in" }),
  }}
  {...props}
>
  {props.children}
</TransitionLink>

有关更多信息,请查看他们的 docs .

关于reactjs - 无法使用 graphQL 和 createPages 在 Gatsby 中进行转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52774766/

相关文章:

gatsby - Netlify 部署失败

javascript - 使用 Storybook 解决组件中的绝对/别名导入问题

reactjs - 来自 Laravel-mix(Reactjs 和 Laravel)中组件的未解析图像路径

javascript - 如何在 gatsby 中获取布局文件中的路径名

python - 分层状态机: on_enter on nested machine calls parent methods

ios - 半透明导航栏覆盖推送 View Controller ?

jquery - 如何将多个转换与 jQuery 结合起来?

javascript - 操作 get(this.props 'data' ) 的数据输出

java - React 应用程序不向 java 服务器发送 header

javascript - react 无限循环