我一直在努力了解如何设法制作一个能够经常接收新数据并将其推向前端的ListView。使用下面的代码,列表没有正确反映更改,而不是在顶部有一个新行,最后一个是重复的..
'use strict';
var React = require('react-native');
var {
AppRegistry,
StyleSheet,
Text,
View,
ListView,
TouchableHighlight,
} = React;
var listview = React.createClass({
rows: [],
_rowHasChanged: function (r1, r2) {
// if (r1 !== r2)
// console.log('rowChanged', r1, r2);
// else
// console.log('row didn\'t Changed', r1, r2);
return r1 !== r2;
},
getInitialState: function() {
return {
dataSource: new ListView.DataSource({rowHasChanged: this._rowHasChanged}),
};
},
componentDidMount: function () {
this.rows = [
{id: 0, text: '0: text'},
{id: 1, text: '1: text'},
{id: 2, text: '2: text'},
{id: 3, text: '3: text'},
];
this.setState({
dataSource: this.state.dataSource.cloneWithRows(this.rows),
});
},
pushTopRow: function () {
var id = this.rows.length;
this.rows.unshift({id: id, text: id + ': text'});
this.setState({
dataSource: this.state.dataSource.cloneWithRows(this.rows),
});
},
render: function() {
return (
<View style={styles.container}>
<ListView
dataSource={this.state.dataSource}
renderRow={(rowData) => <Text key={rowData.id}>{rowData.text}</Text>}
/>
<TouchableHighlight
onPress={this.pushTopRow}>
<Text>PUSH TOP</Text>
</TouchableHighlight>
</View>
);
},
});
var styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: 'orange',
},
});
AppRegistry.registerComponent('listview', () => listview);
然后我尝试了:
pushTopRow: function () {
var id = this.rows.length;
var newRow = [{id: id, text: id + ': text'}];
this.rows = newRow.concat(this.rows);
this.setState({
dataSource: this.state.dataSource.cloneWithRows(this.rows),
});
},
这实际上有效,但我不明白为什么第一种方法不起作用。我试图找出使用ListView处理的最佳实践:
缺乏文件和例子,为我和任何人澄清它会很棒。谢谢你&amp;有一个很好的代码日。
答案 0 :(得分:3)
ListView按数据源索引分配组件键,因此每当数据源被预先添加时,它都会重新呈现所有行。如果您的行数据具有任何唯一ID,则可以创建使用该行作为键的已修改ListView。请参阅示例PrependableListView,它将在行数据上使用id属性。
注意:此组件不是通用的,如果没有定义id属性,则会失败。
注意:我意识到这不能回答你的整个问题,只是关于预先加入数据源的一个特定的特殊性。