Gatsby: Cara meneruskan variabel dari gatsby-node.js ke halaman

Dibuat pada 19 Mei 2019  ·  1Komentar  ·  Sumber: gatsbyjs/gatsby

Ini adalah bagian dari kode saya saat ini

        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,
            },
          })
        })

Saya bertanya-tanya bagaimana saya bisa mengirimkan date sebagai prop ke _single.js_ atau cara lain yang saya dapat menurunkan nilainya.

question or discussion

Komentar yang paling membantu

@ Hipotesis-github sebelumnya, apakah Anda menggunakan api createPage untuk memasukkan data ke dalam satu komponen? atau single itu sebenarnya adalah template? Dan yang mungkin Anda inginkan adalah seperti ini:

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,
            },
          })
        })

Dan pada 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

Jangan ragu untuk memberikan umpan balik

>Semua komentar

@ Hipotesis-github sebelumnya, apakah Anda menggunakan api createPage untuk memasukkan data ke dalam satu komponen? atau single itu sebenarnya adalah template? Dan yang mungkin Anda inginkan adalah seperti ini:

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,
            },
          })
        })

Dan pada 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

Jangan ragu untuk memberikan umpan balik

Apakah halaman ini membantu?
0 / 5 - 0 peringkat

Masalah terkait

dustinhorton picture dustinhorton  ·  3Komentar

dustinhorton picture dustinhorton  ·  3Komentar

andykais picture andykais  ·  3Komentar

magicly picture magicly  ·  3Komentar

benstr picture benstr  ·  3Komentar