0

我是使用 typescript 和 next.js 的新手。我正在使用 Vercel 部署 Next.js webapp,它将使用 Prisma 从 heroku postgresSQL db 中提取数据。我正在尝试使用 observable/d3 在页面上呈现一些数据,使用 getStaticProps 获取数据,然后将其传递给主页组件。

export const getStaticProps: GetStaticProps = async () => {
    let data: Array<object> = await prisma.test.findMany()
    console.log(data)
    return { props: { data } }
}

const Home: NextPage = ( data ) => {
    console.log(data)
    useEffect(() => {
    document.body.append(
        Plot.barY(data, {x: "letter", y: "frequency"}).plot()
    )
 }, [])
 ...
}

getStaticProps 中的第一个控制台日志以我想要的格式返回数据,一个对象数组:

[
 {letter: 'A', frequency: 0.0123}
 ...
 {letter: 'Z', frequency: 0.00234}
]

将数据传递给 Home 组件后,data它被包装在一个对象中,如下所示:

 {
  data: [
   {letter: 'A', frequency: 0.0123}
   ...
   {letter: 'Z', frequency: 0.00234}
  ]
 }

我的绘图函数需要一个对象数组,但是在data使用 getStaticProps 将其传递给 Home 组件后,data会被“包裹”在那些 JS Curley 大括号中,我不希望这样。有人可以帮我理解为什么以及如何纠正这种行为吗?在两个 console.log 中使用 typeof 数据返回object

4

1 回答 1

0

你应该已经解构了道具Home({ data })而不是Home(data)

import { InferGetStaticPropsType } from 'next'

type Test = {
  letter: string
  frequency: number
}

export const getStaticProps = async () => {
  let data: Test[] = await prisma.test.findMany()
  return {
    props: {
      data
    }
  }
}

// Destructure the props
const Home: NextPage = ({ data }: InferGetStaticPropsType<typeof getStaticProps>) => {
  // will resolve tests to type Test[]
}
于 2021-11-10T01:22:00.827 回答