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

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

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

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

Q&A

解決済

1回答

2299閲覧

Typescript Object[key]を参照しようとするとエラーになる

wlo0603

総合スコア1

TypeScript

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

0グッド

0クリップ

投稿2021/10/26 01:04

前提・実現したいこと

閲覧ありがとうございます
現在動的なオブジェクトを生成してブラケット記法で値を参照しようとしているのですが、
エラーになり参照できません。解決方法や別の方法で実現できるのであればご助言いただけると助かります

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

下記はVSCodeのエラーメッセージです

型 'any' の式を使用して型 '{}' にインデックスを付けることはできないため、要素は暗黙的に 'any' 型になります。

該当のソースコード

typescript

1const propVale = [{id:'name',name:'名前'},{id:'age',name:'年齢'},{id:'sex',name:'性別'}] 2 3const propValueById = propVale.reduce((previousValue,currentValue)=>{ 4 previousValue = Object.assign(previousValue,{[currentValue.id]:currentValue}) 5 return previousValue 6},{}) 7 8function fetchValue(id){ 9 return propValueById[id] 10} 11 12fetchValue('name')

試したこと

ネットで色々調べたのですが今回のような型宣言ができない場合の解決方法が思い浮かびませんでした

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

Angularで開発しています
typescriptの設定によってはエラーが出ないかもしれません

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

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

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

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

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

guest

回答1

0

ベストアンサー

今回のような型宣言ができない場合

できます。

typescript

1const propValueById = propVale.reduce((previousValue,currentValue)=>{ 2 previousValue = Object.assign(previousValue,{[currentValue.id]:currentValue}) 3 return previousValue 4},{} as Record<string, string | undefined>) 5 6function fetchValue(id: string){ 7 return propValueById[id] 8}

投稿2021/10/26 01:13

maisumakun

総合スコア145208

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

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

wlo0603

2021/10/26 01:42

Record というものがあったのですね・・・ 勉強になりました! ご回答ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問