Невозможно получить переходы для работы в Гэтсби, используя graphQL и createPages

Я сделал git клон gatsby-wordpress-starter ( https://www.gatsbyjs.org/starters/?c=Wordpress)

Не внося никаких изменений, я добавил позу: ( https://popmotion.io/pose/examples/route-transitions-reach-router/)

Следуя инструкциям на приведенном выше URL-адресе, я изменил файл component /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: Невозможно прочитать свойство 'map' из неопределенного

Если я разверну файл console.log "location", там не будет "ключа"

Чтобы добавить к этому, я также попытался установить официальный плагин перехода Гэтсби, и это также не работает должным образом. Это делает входной переход, но не выходной переход. Он запускает завершенный переход, но только после изменения содержимого страницы.

0 ответов

Я бы предложил другой подход, который я всегда использовал для создания переходов между страницами (как с постепенным появлением, так и с постепенным исчезновением и др.): С использованием gatsby-plugin-transition-link. Я не уверен, какой из них вы пробовали, но этот работает и имеет более чистый и семантический подход.

Он позволяет вам создавать свою собственную анимацию или использовать какие-то стандартные или предопределенные, вы можете проверить его демонстрационный сайт здесь, где есть пример нескольких переходов.

Для предопределенных переходов (самый простой способ) вам нужно только импортировать компонент de и использовать его следующим образом:

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

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

Для настраиваемых переходов вам необходимо определить de entry и выйти 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>

Для получения дополнительной информации ознакомьтесь с их документами.

Другие вопросы по тегам