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

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

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

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

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

React.js

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

Q&A

解決済

1回答

3235閲覧

typescript ネストする配列の定義方法

whiwhdiw

総合スコア70

JavaScript

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

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

React.js

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

0グッド

0クリップ

投稿2020/03/16 02:48

jsxをtsx&hooksに書き換えています。
stateで管理しているGroupsというstateがあり、その型を定義したいです。
下記でGroupsの配列を定義してあげたのですが、childrenの中にはその子供
のGroupsが入っていて、その子供のGroupsのchildrenの中にもGroupsが入っているという構造です。
どうやって定義したらいいのでしょうか?

interface Groups { id: number; name: string; children: // どう定義したらいいのかがわからない; }
**Groupの配列の中身** ▼[{…}]  ▼0:   id: 100   name: "太郎"   mail: taro@eee.com   ▼children: Array(2)    0: {id:120, name: "山田", email: yamada@eee.com}   ▼1:     id: 121     name: "佐藤"     email: "sato@eee.com"     children: Array(1)

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

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

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

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

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

guest

回答1

0

ベストアンサー

どうやって定義したらいいのでしょうか?

普通に書けばいいです。

typescript

1interface Groups { 2 id: number; 3 name: string; 4 children: Groups[]; 5}

投稿2020/03/16 02:52

編集2020/03/16 02:54
maisumakun

総合スコア146018

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

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

whiwhdiw

2020/03/16 02:54

これで勝手にtypescriptが解釈してくれるということでしょうか?
maisumakun

2020/03/16 02:56

自分自身の中で自分自身を使う再帰的な定義は可能です。 (型名の間違いがありましたので修正しました)
whiwhdiw

2020/03/16 03:09

ありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問