Firebase -- 批量删除子节点
Posted
技术标签:
【中文标题】Firebase -- 批量删除子节点【英文标题】:Firebase -- Bulk delete child nodes 【发布时间】:2016-10-31 06:31:56 【问题描述】:我正在使用 reactFire、Firebase 和 reactJS 构建一个简单的待办事项应用程序。我遇到的问题是当我尝试批量删除列表中已完成的条目时。
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();
循环提前结束,即在删除所有已完成的条目之前,因为调用了渲染函数。
【问题讨论】:
done
是项目分支内的布尔值,对吗?
您运行的是哪个版本的 firebase?我问是因为 react-fire 不支持对 FB API 的最新更改。
@adolfosrs 是的,它是 @U r s u s,我使用的是 firebase 3.0.5 和 reactfire 1.0.0
【参考方案1】:
您可以使用多位置更新一次性删除所有已完成的项目:
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);
【讨论】:
"// 将值设置为 null 会删除密钥。"这正是我需要的,谢谢! 如果将值设置为null
会删除键,如何将键更新为空值?
@Crashalot null
是无效密钥以上是关于Firebase -- 批量删除子节点的主要内容,如果未能解决你的问题,请参考以下文章