2016-10-18 8 views
0

私は単純なjson APIを持っていて、反応のあるいくつかのオブジェクトフィールドを表示したい。 は、APIには、以下の構造を有する:Reactオブジェクトを別のオブジェクトの中に入れよう

{"data" : [ 
    0: Object 
    id: "1" 
    type: "Item" 
    attributes: Object 
     title: "lorem impsum" 
     body: "lorem ipsum" 

    1: Object 
    id: "2" 
.... 
]} 

そして、私が表示しようとしている項目(タイトル、本文を)属性

を問題は

これが正常に動作し、ID

を表示するということです
{items.map(item => 
    <div>{item.id}</div> 
)} 

BUT

0123を使用しようとすると私はそうitem.attributesが定義されていない

TypeError: Cannot read property 'title' of undefined

を受けます。

ここで何が間違っていますか?

+1

すべての項目に 'attributes'フィールドが定義されていますか? – Matias

+1

'{item.attributes && item.attributes.title}'を試し、出力が – Maxx

+0

であることを確認しました。属性フィールドのいくつかは 'null'値を持っています。 '{item.attributes && item.attributes.title}' - これは機能します。私はそれを得たと思う。ありがとう。 – kirqe

答えて

1

これはあなたがサーバから取得しようとしているオブジェクトを知っていることはありませんので、発生した最も一般的なエラーであるため、常にデータにアクセスする前にチェックするための良い方法です、あなたので、試すことができます

{item.attributes && item.attributes.title ? item.attributes.title : 'print something for missing title' } 

//item.attributes && item.attributes.title means if both the values are present in Object 
1

これはあなたに役立つでしょう。あなたのプログラムでエラーが見つかりませんでした。ですから、これを解決するための実例を作成しました。

const data = { 
 
    "data": [{ 
 
    id: "1", 
 
    type: "Item", 
 
    attributes: { 
 
     title: "lorem impsum", 
 
     body: "lorem ipsum", 
 
    } 
 
    }, { 
 
    id: "1", 
 
    type: "Item", 
 
    attributes: { 
 
     title: "lorem impsum", 
 
     body: "lorem ipsum", 
 
    } 
 
    }, { 
 
    id: "1", 
 
    type: "Item", 
 
    attributes: { 
 
     title: "lorem impsum", 
 
     body: "lorem ipsum", 
 
    } 
 
    }, { 
 
    id: "1", 
 
    type: "Item", 
 
    attributes: { 
 
     title: "lorem impsum", 
 
     body: "lorem ipsum", 
 
    } 
 
    }] 
 
} 
 

 
class Sample extends React.Component{ 
 
    render() { 
 
    return <div> 
 
     { 
 
     data.data.map((el) => { 
 
      return <div> 
 
      <h1>{el.id}</h1> 
 
      <div>{el.attributes.title}</div> 
 
      <div>{el.attributes.body}</div> 
 
      </div> 
 
     }) 
 
     } 
 
     </div> 
 
    } 
 
} 
 

 
ReactDOM.render(<Sample/>, document.getElementById('app'))
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script> 
 
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script> 
 
<div id="app"></div>

関連する問題