如何从 json 中提取数据并在 Next.js 中作为 props 传递

Posted

技术标签:

【中文标题】如何从 json 中提取数据并在 Next.js 中作为 props 传递【英文标题】:How to extract data from json and pass as props in Next.js 【发布时间】:2021-03-03 17:19:15 【问题描述】:

我目前陷入这种情况:

    我需要将props 传递给组件以填充DataGrid 因此,我使用getStaticProps 从 API 获取 JSON 数据,然后作为道具返回。 但是,我只需要 JSON 文件的每个条目中的 3 个属性,并且我必须仅将这 3 个属性作为道具传递给 DataGrid

问题:如何将每个条目(大约 50 个条目)中的 3 个 json 属性提取到我自己的 JSON 对象中。然后,将 JSON 对象作为 props 返回?

我当前的代码:

  export async function getStaticProps()
  const res = await fetch ('https://api.link.example')
  const data = await res.json()

  return
    props: 
      data
    ,
  

组件代码

export default function dashboard(data)
return (
    <Layout>
    <div style= height: 400, width: '100%' >
        <DataGrid rows=data  /*material UI kit*/
        columns=columns 
        pageSize=5 
        checkboxSelection 
        disableSelectionOnClick="true" />
    </div>
    </Layout>
)

示例 JSON

["total": 121227292170, 
"high": 74886, (require)
"low": 71316, (require)
"price": 2847.93, (require)
"price_change": 3.95671,,

"total": 121227292170, 
"high": 74886, (require)
"low": 71316, (require)
"price": 2847.93, (require)
"price_change": 3.95671,]

【问题讨论】:

【参考方案1】:

这是你想要的吗?

let data = await res.json()

data = data.map(item => 
    
     const  price, high, low  = item
     return  price, high, low 
)

.map 将遍历所有对象,return 语句将只返回你想要的键。

【讨论】:

你是个救命稻草!

以上是关于如何从 json 中提取数据并在 Next.js 中作为 props 传递的主要内容,如果未能解决你的问题,请参考以下文章

如何加入从我的数组的每个元素的数据库中提取的结果并在 Laravel 8 中以 json 形式返回

如何使用 JSON 从 Reddit API 中提取 url 数据

Next Js 服务端 Api 读写 JSON

如何提取 useTranslate 作为辅助函数而不是组件?

如何从 Message 中提取数据并在 Notification(Android) 中显示

从 JSON 文件动态加载图像位置 - (找不到模块...) React, Next.js