首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法使用graphQL和createPages在get中进行转换

无法使用graphQL和createPages在get中进行转换
EN

Stack Overflow用户
提问于 2018-10-12 15:49:17
回答 1查看 199关注 0票数 5

我做了一个git克隆的gatsby-wordpress-starter (https://www.gatsbyjs.org/starters/?c=Wordpress)

没有做任何更改,我添加了姿势:(https://popmotion.io/pose/examples/route-transitions-reach-router/)

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

代码语言:javascript
复制
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 : Cannot read property‘TypeError’of undefined

如果我展开'location‘的console.log,里面没有'key’

除此之外,我还尝试安装了官方的gatsby转换插件,但也不能正常工作。它执行进入转换,但不执行退出转换。它会触发已退出的转换,但直到页面内容更改之后才会启动。

EN

回答 1

Stack Overflow用户

发布于 2020-03-22 16:35:19

我建议使用另一种方法来创建页面过渡(包括淡入、淡出等):使用gatsby-plugin-transition-link。我不确定你尝试过哪一种,但这一种很有效,而且更简洁,更具语义性。

它允许你创建你的自定义动画或者使用一些默认的或者预定义的,你可以查看它的演示站点here,在那里有一些过渡的例子。

对于预定义的转换(最简单的方法),您只需导入de component并像这样使用它:

代码语言:javascript
复制
import AniLink from "gatsby-plugin-transition-link/AniLink"

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

对于自定义转换,您需要定义de entry并退出effect,例如:

代码语言:javascript
复制
<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

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

https://stackoverflow.com/questions/52774766

复制
相关文章

相似问题

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