![](/img/trans.png)
[英]$.each is only iterating through the last item in my array…Why is this happening?
[英]Iterating array for each item in javascript
我有一个对象数组,我想循环遍历一次 。 这是javascript的代码。
data.projectModelList.sum = function (prop) {
var total = 0;
for (var i = 0, _len = this.length; i < _len; i++) {
total += this[i][prop];
}
return total;
}
vm.dataTotal = [data.projectModelList.sum("budget"),
data.projectModelList.sum("tax"),
data.projectModelList.sum("money"),
data.projectModelList.sum("balance"),
data.projectModelList.sum("amount"),
data.projectModelList.sum("current"),
data.projectModelList.sum("after"),
data.projectModelList.sum("discount")]
当我循环浏览时,我得到的预算,税收,金钱,余额,金额,当期,以后,折扣都超过1。我只想循环浏览,然后结果必须是每个项目都显示一次且不能再显示一次。 我知道我需要在for循环中更改某些内容,但我不知道该怎么做。
亲切的问候
编辑:
模型项
public class ProjectDashBoardModel
{
public decimal budget { get; set; }
public decimal tax{ get; set; }
public decimal money{ get; set; }
public decimal balance{ get; set; }
public decimal amount{ get; set; }
public decimal current{ get; set; }
public decimal after{ get; set; }
public decimal discount{ get; set; }
}
public class ProjectDashboard
{
public Guid Id { get; set; }
public string ProjectLogo { get; set; }
public string LastMutatedBy { get; set; }
public DateTime LastMutatedDate { get; set; }
public List<ProjectDashBoardModel> ProjectModelList { get; set; }
}
您可以更改sum
函数以返回一个具有所有 sum作为属性的对象-这意味着您只需要循环一次数组即可。
data.projectModelList.sum = function (props) {
var total = {};
for (var i = 0, _len = this.length; i < _len; i++) {
for(var j=0;j<props.length;i++){
var prop = props[j];
if(total[prop] === undefined){
total[prop] = 0;
}
total[prop] += this[i][prop];
}
}
return total;
}
您可以使用所需的所有属性的数组来调用它:
var sums = data.projectModelList.sum(['budget','tax','money']);
然后,您将使用点或括号符号读取总和
var budgetTotal = sums.budget;
var moneyTotal = sums['money'];
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.