Reputation: 55
I am a beginner in programming. I want to do the sum of all elements in an array. I made this but I can't see where are my mistakes?
function ArrayAdder(_array) {
this.sum = 0;
this.array = _array || [];
}
ArrayAdder.prototype.computeTotal = function () {
this.sum = 0;
this.array.forEach(function (value) {
this.sum += value;
});
return this.sum;
};
var myArray = new ArrayAdder([1, 2, 3]);
console.log(myArray.computeTotal());
Upvotes: 5
Views: 26271
Reputation: 22723
Try this:
let arr = [1, 2, 3, 4, 5];
const sum = arr.reduce((x, y)=> x+y);
console.log(sum);
Upvotes: 0
Reputation: 87203
this
inside the forEach
callback refers to the global window
object. To set the context of the callback, use the Array#forEach
second argument to pass the context.
this.array.forEach(function (value) {
this.sum += value;
}, this); // <-- `this` is bound to the `forEach` callback.
function ArrayAdder(_array) {
this.sum = 0;
this.array = _array || [];
}
ArrayAdder.prototype.computeTotal = function () {
this.sum = 0;
this.array.forEach(function (value) {
this.sum += value;
}, this);
return this.sum;
};
var myArray = new ArrayAdder([1, 2, 3]);
console.log(myArray.computeTotal());
document.write(myArray.computeTotal()); // For Demo purpose
If you're looking for an alternative, you can use Array#reduce
, here using with Arrow function
var sum = arr.reduce((x, y) => x + y);
// Note: If this doesn't work in your browser,
// check in the latest version of Chrome/Firefox
var arr = [1, 2, 3];
var sum = arr.reduce((x, y) => x + y);
document.write(sum);
Upvotes: 12
Reputation: 6010
The most effective way of doing this is to use the reduce array function. For example:
this.array = [0, 1, 2, 3]
this.sum = this.array.reduce(function(a, b) {
return a + b;
});
Upvotes: 1
Reputation: 28445
Reference of this
got changed in forEach
function. Update your code to following
function ArrayAdder(_array) {
this.sum = 0;
this.array = _array || [];
}
ArrayAdder.prototype.computeTotal = function() {
this.sum = 0;
var that = this;
this.array.forEach(function(value) {
that.sum += value;
});
return this.sum;
};
var myArray = new ArrayAdder([1, 2, 3]);
console.log(myArray.computeTotal());
The above saved the reference of this
in that
and used it for computing.
Upvotes: 3