Reactの使用解析されたJSONファイルを渡してオブジェクトをマップしようとしています。しかし、私は私のデータ構造の最上位レベルにアクセスすることができるよ、これを使用してReactの子コンポーネントへのオブジェクトのマッピング
const question = Object.keys(questions).map((data, index) =>
<QuestionList questions={data} key={index} />
:それは私だけで以下のようにObject.keysを使用してオブジェクトをマッピングすることができるオブジェクトであるとして、しかし、見て。だからこのコードを使用して、私のオブジェクトを渡します。 Object.keys()を使用すると、「質問」や「q1」やタイプ、テキスト、qIdなどしかアクセスできません。すべてのオブジェクトプロパティを一度に渡すことはできず、子コンポーネントで必要なものを指定することはできません。私は子コンポーネントでこれらを使用できるように、子プロパティを持つオブジェクト全体を渡すための最も簡単な方法は何でしょう
"questions": {
"q1": {
"qId": "1",
"type": "YN",
"text": "Text 1",
"tip": {
"logo": "assets/icons/gadgetz.svg",
"logofallback": "assets/img/gadgetz.png",
"heading": "Heading 1",
"text": "Text 2"
}
},...
?私は小道具以外の何かを使わなければならないのですか?
なぜオブジェクト全体を渡すことができないのですか? –
はい、Prop Typeとしてオブジェクトを渡すことができます。問題は、画像へのパスである値を渡していることです。ウェブパックを使用している場合は問題になる可能性があります。 – redconservatory
これはうまくいくはずですが、エラーは他の場所にあります。このコードので、私はこれが動作しないと考える理由がある : '{JSON.stringify(this.props.questions)}' リターンキーだけ "質問"、 "Q1、Q2、Q3"、または"qId、type、text"は、オブジェクトをどのように渡すかによって異なります。 '{JSON.stringify(this.props.questions.q1)}'と書くと、オブジェクトは空です。 – dwigt