質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Next.js

Next.jsは、Reactを用いたサーバサイドレンダリングなどを行う軽量なフレームワークです。Zeit社が開発しており、nextコマンドでプロジェクトを作成することにより、開発環境整備が整った環境が即時に作成できます。

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

1回答

4256閲覧

連想配列をfetchしたいがUnhandled Runtime Error

Akihide

総合スコア8

Next.js

Next.jsは、Reactを用いたサーバサイドレンダリングなどを行う軽量なフレームワークです。Zeit社が開発しており、nextコマンドでプロジェクトを作成することにより、開発環境整備が整った環境が即時に作成できます。

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2020/10/17 11:56

編集2020/10/17 12:43

前提・実現したいこと

reactで非同期通信によりjsonを取得し表示したいですが、下記のエラーになります。
原因、対応方法がわかる方ご教示お願いいたします。

発生している問題・エラーメッセージ

Unhandled Runtime Error Error: Objects are not valid as a React child (found: [object Promise]). If you meant to render a collection of children, use an array instead.

該当のソースコード

JavaScript

1const CSV = () => { 2 async function getJson() { 3 const res = await fetch('https://script.googleusercontent.com/macros/echo?user_content_key=v5nAejLstPehuklsZmNJPa9QDqUp1Bk02DeXyF5HMdzNHqzk5ojX-B9wIFKxnIy9JsJd1Gi5_jeTBPfLQvNdZ4wh2j6q_DHsm5_BxDlH2jW0nuo2oDemN9CCS2h10ox_1xSncGQajx_ryfhECjZEnFKfE7MeVBE3mJAOQZdw2vGGe1QohVrhsCYtd5Xm2mrGuvs5Gzq5Johck3wUpibyKTOmbnRGq-tk&lib=MSp2QuS9Md5bx-zXxd-nCTnk9R_C2Jzti') 4 const jsonData = await res.json() 5 return jsonData 6 } 7 return ( 8 <> 9 {getJson()} 10 </> 11 ) 12}

補足情報(FW/ツールのバージョンなど)

"next": "9.5.3", "react": "16.13.1",

fetch先のリンクは問題なくjsonを取れてきています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

reactはよくわからないのですが、普通のjsでやるとこう

javascript

1<script> 2const CSV = () => { 3 async function getJson() { 4 const res = await fetch('https://script.googleusercontent.com/macros/echo?user_content_key=v5nAejLstPehuklsZmNJPa9QDqUp1Bk02DeXyF5HMdzNHqzk5ojX-B9wIFKxnIy9JsJd1Gi5_jeTBPfLQvNdZ4wh2j6q_DHsm5_BxDlH2jW0nuo2oDemN9CCS2h10ox_1xSncGQajx_ryfhECjZEnFKfE7MeVBE3mJAOQZdw2vGGe1QohVrhsCYtd5Xm2mrGuvs5Gzq5Johck3wUpibyKTOmbnRGq-tk&lib=MSp2QuS9Md5bx-zXxd-nCTnk9R_C2Jzti') 5 const jsonData = await res.json() 6 return jsonData 7 } 8 return getJson(); 9} 10(async()=>{ 11 console.log(await CSV()); 12})(); 13</script>

CSVが返すのはpromiseなので、呼び出し側をasyncとしてawaitで呼び出すことです

投稿2020/10/17 13:05

yambejp

総合スコア116734

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Akihide

2020/10/17 13:14

呼び出し側もasyncなんですね。。 ありがとうございます。 勉強になりました。解決です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問