编辑:我设法使用下面的代码延迟初始加载,因此它现在正确读取并在启动时显示文件名。现在我唯一的问题是在某些数据发生变化时立即更新部分列表。
componentWillMount() {
setTimeout(() => {
this.sortAndPlace(this.state.list, this.state.songs)
})
}
我正在尝试构建一个应用程序,我是新的反应本机及其所有库。我想用react-native-fs读取文件,从那里构建一个sectionlist数据,当文件被添加,删除和修改时,我想用状态更新来反映这个变化。
RNFS.readDir(path)
.then((result) => {
// log the file contents
return Promise.all(result)
})
.then((contents) => {
for (var i = 0; i < contents.length; i++) {
if (contents[i].isFile() && contents[i].name !== "ReactNativeDevBundle.js")
{
var labelTemp = contents[i].name.split(".")
var label = labelTemp[0]
song.push(new Song(label))
}
/*RNFS.unlink(contents[i].path)
.then(() => {
console.log('FILE DELETED');
})
// `unlink` will throw an error, if the item to unlink does not exist
.catch((err) => {
console.log(err.message);
});*/
}
})
sortAndPlace(secArray ,array) {
sectionNames = []
filteredSectionNames = []
for (var i = 0; i < array.length; i++) {
sectionNames.push(array[i].name.substring(1,0))
}
filteredSectionNames = sectionNames.filter(function(item, pos) {
return sectionNames.indexOf(item) == pos;
}).sort()
for (var i = 0; i < filteredSectionNames.length; i++) {
secArray[i] = {id: i, title: filteredSectionNames[i], data: []}
}
for (var i = 0; i < secArray.length; i++) {
for (var j = 0; j < array.length; j++) {
if (array[j].name.substring(1,0) === secArray[i].title) {
secArray[i].data[secArray[i].data.length] = {id: j, text:
array[j].name}
}
}
}
function compare(a,b) {
if (a.text < b.text)
return -1;
if (a.text > b.text)
return 1;
return 0;
}
for (var k = 0; k < secArray.length; k++) {
secArray[k].data.sort(compare);
}
this.setState({
list: secArray,
songs: array
})
}
我正在使用我的手机进行测试“react-native run-android”。承诺组成歌曲阵列的时间较晚,因此有时app会打开数据,有时我必须重新进入才能看到数据。当我修改文件并重新创建数组时,我必须完全关闭应用程序并启动它以查看更改。 redux能解决这个问题吗?你能就如何解决这个问题向我提出建议吗? 提前谢谢!
答案 0 :(得分:0)
由于我发现了我的粗心错误,我将回复这篇文章。事实证明我并没有正确地绑定这些功能。现在它起作用了。抱歉你的时间。