Easiest to explain with code:
##### module.js
var count, incCount, setCount, showCount;
count = 0;
showCount = function() {
return console.log(count);
};
incC
Correct me if I am wrong, but numbers are immutable types. When you change the value of count
then your reference changes too. So exports.count
references to the old count
value.
In JavaScript, functions and objects (including arrays) are assigned to variables by reference, and strings and numbers are assigned by value--that is, by making a copy. If var a = 1
and var b = a
and b++
, a
will still equal 1.
On this line:
exports.count = count; // let's also export the count variable itself
you made a by-value copy of the count variable. The setCount(), incCount() and showCount() operations all operate on the count variable inside the closure, so m.count doesn't get touched again. If those variables were operating on this.count, then you'd get the behavior you expect--but you probably don't want to export the count variable anyway.
exports.count = count
Your setting a property count
on an object exports
to be the value of count
. I.e. 0.
Everything is pass by value not pass by reference.
If you were to define count
as a getter like such :
Object.defineProperty(exports, "count", {
get: function() { return count; }
});
Then exports.count
would always return the current value of count
and thus be 11