Gatsby: Comment passer une variable de gatsby-node.js aux pages

Créé le 19 mai 2019  ·  1Commentaire  ·  Source: gatsbyjs/gatsby

C'est ma partie de mon code en ce moment

        const posts = result.data.allCockpitHello.edges
        const date = new Intl.DateTimeFormat("default", {
          month: "short",
          day: "2-digit",
          year: "numeric",
        }).format(posts.node.cockpitCreated,);
        posts.forEach((post, index) => {
          const previous = index === posts.length - 1 ? null : posts[index + 1].node
          const next = index === 0 ? null : posts[index - 1].node

          createPage({
            path: `/blog/${post.node.Name.value}`,
            component: path.resolve(`./src/components/single.js`),
            context: {
              slug: post.node.Name.value,
              date,
              previous,
              next,
            },
          })
        })

Je me demandais comment je pouvais passer date comme accessoire à _single.js_ ou de toute autre manière que je puisse transmettre la valeur.

question or discussion

Commentaire le plus utile

@ Hypothesis-github avant tout, utilisez-vous l'api createPage pour injecter des données dans des composants uniques? ou ce single est en fait un modèle? Et ce que vous voulez probablement, c'est quelque chose comme ceci:

const posts = result.data.allCockpitHello.edges
        const date = new Intl.DateTimeFormat("default", {
          month: "short",
          day: "2-digit",
          year: "numeric",
        }).format(posts.node.cockpitCreated,);
        posts.forEach((post, index) => {
          const previous = index === posts.length - 1 ? null : posts[index + 1].node
          const next = index === 0 ? null : posts[index - 1].node

          createPage({
            path: `/blog/${post.node.Name.value}`,
            component: path.resolve(`./src/components/single.js`),
            context: {
              slug: post.node.Name.value,
              cockpidate:date,
              previousitem:previous,
              nextitem:next,
            },
          })
        })

Et sur single.js :

import React from "React"
import {Link} from "gatsby"

const Single=props=>{
   const {pageContext}= props
   const {slug,cockpidate,nextitem,previousitem}= pageContext
  return (
      <div>
        <h3>{slug}</h3>
         <hr/>
         <h5>created at {cockpidate}</h5>
         <Link to={nextitem}/>next item</Link>
          <Link to={previousitem}/>previousitem</Link>
       <div>
  )
}
export default Single

N'hésitez pas à nous faire part de vos commentaires

>Tous les commentaires

@ Hypothesis-github avant tout, utilisez-vous l'api createPage pour injecter des données dans des composants uniques? ou ce single est en fait un modèle? Et ce que vous voulez probablement, c'est quelque chose comme ceci:

const posts = result.data.allCockpitHello.edges
        const date = new Intl.DateTimeFormat("default", {
          month: "short",
          day: "2-digit",
          year: "numeric",
        }).format(posts.node.cockpitCreated,);
        posts.forEach((post, index) => {
          const previous = index === posts.length - 1 ? null : posts[index + 1].node
          const next = index === 0 ? null : posts[index - 1].node

          createPage({
            path: `/blog/${post.node.Name.value}`,
            component: path.resolve(`./src/components/single.js`),
            context: {
              slug: post.node.Name.value,
              cockpidate:date,
              previousitem:previous,
              nextitem:next,
            },
          })
        })

Et sur single.js :

import React from "React"
import {Link} from "gatsby"

const Single=props=>{
   const {pageContext}= props
   const {slug,cockpidate,nextitem,previousitem}= pageContext
  return (
      <div>
        <h3>{slug}</h3>
         <hr/>
         <h5>created at {cockpidate}</h5>
         <Link to={nextitem}/>next item</Link>
          <Link to={previousitem}/>previousitem</Link>
       <div>
  )
}
export default Single

N'hésitez pas à nous faire part de vos commentaires

Cette page vous a été utile?
0 / 5 - 0 notes

Questions connexes

theduke picture theduke  ·  3Commentaires

brandonmp picture brandonmp  ·  3Commentaires

timbrandin picture timbrandin  ·  3Commentaires

kalinchernev picture kalinchernev  ·  3Commentaires

Oppenheimer1 picture Oppenheimer1  ·  3Commentaires