如何获取我的flatList来渲染带有嵌套对象的Array对象作为useState的属性?

时间:2019-09-26 12:05:41

标签: reactjs react-native realm react-hooks

我要执行以下操作: 1)从API检索数据 2)将其存储在本地Realm实例中 3)拉存储在领域中的对象数组并将数据分配给Data挂钩 4)显示在平面列表中

请注意,该对象包含2个对象作为属性。

这是我的JS代码:

 const [data, setData] = useState([]);

 const writeData = response => { //data contains the response 
Realm.open({
  schema: [ExpenseSchema, UserSchema, AmountSchema],inMemory: true
}).then(realm => {
  realm.write(() => {
    response.map(expense => {
        realm.create("expense", expense);
       setData(data => [...data, expense]); //1) works if I do this
    });
   const objects = realm.objects('expense');
   const values =Object.values(objects);
    //setData([values]); //2) this one doesn't work, nor any of the following attempts
//setData(data => [...data, values]);
  //  setData([values]);
    //setData(objects);
 //setData([objects] 
  });
});
};

第二个setData调用是我正在尝试进行的调用,但是在进行Realm查询时对象数组的格式被平面表识别为数据源,并在尝试进行以下操作时抛出以下错误:渲染:

TypeError: undefined is undefined is not an object (evaluating 'item.amount.currency')

以下是适用于flatList数据源的格式的响应,如下所示:

Array [
  Object {
    "amount": Object {
      "currency": "EUR",
      "value": "1854.99",
    },
    "category": "",
    "comment": "",
    "date": "2018-09-10T02:11:29.184Z",
    "id": "5b996064dfd5b783915112f5",
    "index": 0,
    "merchant": "McD",
    "receipts": Array [],
    "user": Object {
      "email": "aaa@ggg.com",
      "first": "Ombly",
      "last": "Lee",
    },
  },
  Object {
    "amount": Object {
      "currency": "GBP",
      "value": "3222.88",
    },
    "category": "",
    "comment": "",
    "date": "2018-08-13T07:11:01.680Z",
    "id": "5b99606474ab17b7820b3922",
    "index": 1,
    "merchant": "BK",
    "receipts": Array [],
    "user": Object {
      "email": "gler@spoto.com",
      "first": "Gler",
      "last": "Spot",
    },
  }, etc....

这是存储后从本地RealmDB请求它的样子:

Array [
  Object {
    "0": Object {  <---- seems this extra line is causing the issues. 
      "amount": Object {
        "currency": "EUR",
        "value": "1854.99",
      },
      "date": 2018-09-10T02:11:29.184Z,
      "id": "5b996064dfd5b783915112f5",
      "merchant": "McD",
      "receipt": null,
      "user": Object {
        "email": "aaa@ggg.com",
        "first": "Ombly",
        "last": "Lee",
      },
    },
    "1": Object {
      "amount": Object {
        "currency": "GBP",
        "value": "3222.88",
      },
      "date": 2018-08-13T07:11:01.680Z,
      "id": "5b99606474ab17b7820b3922",
      "merchant": "BK",
      "receipt": null,
      "user": Object {
        "email": "gler@spoto.com",
        "first": "Gler",
        "last": "Spot",
      },
    }, etc....

基本上,我需要以一种可以用作平面清单数据源的方式从Realm检索数据。

非常感谢您。

修改 API响应的外观如下:

{
"expenses": [
    {
        "id": "5b996064dfd5b783915112f5",
        "amount": {
            "value": "1854.99",
            "currency": "EUR"
        },
        "date": "2018-09-10T02:11:29.184Z",
        "merchant": "McD",
        "receipts": [],
        "comment": "",
        "category": "",
        "user": {
            "first": "Ombly",
            "last": "Lee",
            "email": "aaa@ggg.com"
        },
        "index": 0
    },
    {
        "id": "5b99606474ab17b7820b3922",
        "amount": {
            "value": "3222.88",
            "currency": "GBP"
        },
        "date": "2018-08-13T07:11:01.680Z",
        "merchant": "BK",
        "receipts": [],
        "comment": "",
        "category": "",
        "user": {
            "first": "Gler",
            "last": "Spot",
            "email": "gler@spoto.com"
        },
        "index": 1
    }, etc....
 ]

我的平面列表

 return (
<View>
  <ScrollView>
    <FlatList
      data={data}
      showsVerticalScrollIndicator={false}
      renderItem={({ item }) => (
        <ExpenseCard
          date={item.date}
          category={item.category}
          amount={item.amount.currency + item.amount.value}
          merchant={item.merchant}
          user={
            item.user.first + " " + item.user.last + "\n" + item.user.email
          }
        />
      )}
      keyExtractor={item => item.id}
    />
  </ScrollView>
</View>
  );
}

1 个答案:

答案 0 :(得分:0)

尝试一下:

<FlatList 
     data={this.state.YourApiData.expenses} //You need to access expenses key.
     showsVerticalScrollIndicator={false}
     renderItem={({item,index}) =>
           <View key={index}>
              <View >
                <Text>ID: {item.id}</Text>
                <Text>Amount and Currency: {item.amount.value} - {item.amount.currency}</Text>
                <Text>Date: {item.date}</Text>
               </View>
            </View>
    />