我要执行以下操作: 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>
);
}
答案 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>
/>