Firebase更新回调以检测错误和sucssess

时间:2015-11-09 13:49:29

标签: firebase

如何使此回叫工作?我已经阅读了这些文件,但我出于某种原因无法弄明白?

   var ref = new Firebase("https://xxx.firebaseio.com/public/"+$scope.uid+"/shows/");
var blast = ref.child(show_title);

blast.update({
"show_title": show_title,
"show_image": show_image,
"show_description": show_description,
"show_email": show_email,
"time": Firebase.ServerValue.TIMESTAMP
});

 blast.update("I'm writing data", function(error) {
   if (error) {
    alert("Data could not be saved." + error);
  } else {
    alert("Data saved successfully.");
  }
});

3 个答案:

答案 0 :(得分:13)

弗兰克的解决方案非常适合您的问题。另一种选择是使用更新承诺。如果您一起执行大量操作(在Firebase中经常出现这种情况),这将非常有用。

这是使用承诺

的示例



blast.update({ update: "I'm writing data" }).then(function(){
  alert("Data saved successfully.");
}).catch(function(error) {
  alert("Data could not be saved." + error);
});




答案 1 :(得分:7)

您对update()的第二次调用会在JavaScript控制台中引发此错误:

  

未捕获错误:Firebase.update失败:第一个参数必须是包含要替换的子项的对象。(...)

update的第一个参数必须是一个对象,所以:

blast.update({ update: "I'm writing data" }, function(error) {
  if (error) {
    alert("Data could not be saved." + error);
  } else {
    alert("Data saved successfully.");
  }
});

作为参考,这是documentation for the update() function

答案 2 :(得分:1)

在React ES6中:

var refTypes = db.ref("products").child(productId);

var updates = {};
updates[productId] = newProduct;

refTypes.update(updates).then(()=>{
  console.log("Data saved successfully.");
}).catch((error)=> {
  console.log("Data could not be saved." + error);
});