ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
本稿は JavaScript の配列を JSON 形式の文字列に変換する方法に関する記事です。サーバへの送信や localStorage への保存、ログ出力などで頻繁に必要になる操作です。
使用する関数
| 関数 |
|---|
|
JSON.stringify(value [, replacer [, space ]]) |
value には配列やオブジェクトを渡します。戻り値として JSON 文字列が返ります。
基本的な使い方
|
// 1. 単純配列 |
引数のオプション
| 引数 | 役割 |
|---|---|
value | 変換する値 (配列・オブジェクト・プリミティブ) |
replacer | キーをフィルタする関数または配列。不要なフィールドを除外可能 |
space | 整形時のインデント。数字 (1〜10) または文字列 ("\t"等) |
逆変換 (JSON → 配列・オブジェクト)
|
const json = '[1,2,3]'; |
JSON.stringify の挙動で注意したい型
| 入力 | 結果 |
|---|---|
undefined / 関数 | キーごと無視される (配列内では null に置換) |
NaN / Infinity | null に置換 |
Date | ISO8601 文字列に変換 ("2026-05-13T...") |
BigInt | 例外 (TypeError) |
| 循環参照 | 例外 (TypeError: Converting circular structure to JSON) |
Map / Set | 空オブジェクト {} になる (中身は出ない) |
toJSON() メソッドを持つオブジェクト | その戻り値が使われる |
用途別の応用
| 用途 | 例 |
|---|---|
| fetch 送信 | fetch(url, { method: "POST", body: JSON.stringify(arr), headers: {"Content-Type":"application/json"} }) |
| localStorage 保存 | localStorage.setItem("items", JSON.stringify(arr)) → 復元は JSON.parse |
| ディープコピー (簡易) | const copy = JSON.parse(JSON.stringify(obj)) (Date 等の特殊型は失われる) |
| ログ出力 | console.log(JSON.stringify(obj, null, 2)) で読みやすく |
注意点
- 循環参照があるとエラーになる。対象オブジェクトの構造を見直すか、
replacerでカット - BigIntは変換不可。文字列化してから
JSON.stringifyへ - Date オブジェクトは ISO 文字列になるため、復元側で
new Date()が必要 - private な情報 (パスワードハッシュ等) を含めない。
replacerで除外する - ディープコピー目的で使う場合、
structuredClone()やlodash.cloneDeepのほうが正確
関連
- 親カテゴリ: JSON
- JavaScript本体: JavaScript
- 関連: Fetch API、localStorage、IndexedDB
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- JSONから配列に変換
- 配列からJSONに変換
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?