I am building a simple todo app using reactFire, Firebase, and reactJS. The problem I am running into is when I try to bulk delete completed entries in the list.
componentWillMount: function() {
this.ref = Firebase.database().ref("items/");
this.bindAsArray(this.ref, "items");
this.ref.on('value', this.handleDataLoaded);
}
for (var i in this.state.items) {
var key = items[i]['.key'];
if(items[i].done){
this.ref.child(key).remove();
}
}
The loop ends prematurely i.e. before deleting all the completed entries, because the render function is called.
I am building a simple todo app using reactFire, Firebase, and reactJS. The problem I am running into is when I try to bulk delete completed entries in the list.
componentWillMount: function() {
this.ref = Firebase.database().ref("items/");
this.bindAsArray(this.ref, "items");
this.ref.on('value', this.handleDataLoaded);
}
for (var i in this.state.items) {
var key = items[i]['.key'];
if(items[i].done){
this.ref.child(key).remove();
}
}
The loop ends prematurely i.e. before deleting all the completed entries, because the render function is called.
Share Improve this question edited Jun 28, 2016 at 19:22 Frank van Puffelen 599k85 gold badges888 silver badges858 bronze badges asked Jun 28, 2016 at 19:15 user5415371user5415371 3 |1 Answer
Reset to default 22You can delete all completed items in one go by using a multi-location update:
var updates = {};
for (var i in this.state.items) {
var key = items[i]['.key'];
if(items[i].done){
updates[key] = null; // setting value to null deletes the key
}
}
this.ref.update(updates);
done
is a bollean value inside the item branch right? – adolfosrs Commented Jun 28, 2016 at 19:22