如何使用firebase和angularfire对数组中对象的值进行合计

How can I total values from an object in an array using firebase and angularfire?

本文关键字:对象 firebase 何使用 angularfire 数组      更新时间:2023-09-26

更新以获得更好的问题:

我能够让工厂正常运转,并使它的总数脱离了循环。现在,我很难将该数字显示在视图中,并且每次在列表中添加/删除/更新新项目时都会显示该数字。

"ListWithTotal"工厂的工作原理与文档中的完全相同。我没有正确设置ref变量。

这是最新的相关代码:

//controller
$scope.total = TodoService.getTotalPoints();
//service
var todos = $firebase(ref, {arrayFactory: "ListWithTotal"}).$asArray();
  return {
    getTotalPoints:function(){
         todos.$loaded().then(function() {
        total = todos.getTotal();
        console.log(total);
        return total;
      });
    },

当点值发生变化时,我无法将其返回到视图或进行更新。有人能提供一些方向吗?

AngularFire指南在关于扩展工厂的一节中介绍了这个确切的例子。

app.factory("ListWithTotal", ["$FirebaseArray", "$firebase", function($FirebaseArray, $firebase) {
  // create a new factory based on $FirebaseArray
  var TotalFactory = $FirebaseArray.$extendFactory({
    getTotal: function() {
      var total = 0;
      // the array data is located in this.$list
      angular.forEach(this.$list, function(rec) {
        total += rec.amount;
      });
      return total;
    }
  });
  return function(listRef) {
    // override the factory used by $firebase
    var sync = $firebase(ref, {arrayFactory: TotalFactory});
    return sync.$asArray(); // this will be an instance of TotalFactory
  }
}]);