+ 6
How to access caller object inside the method declared as prototype in JavaScript?
I have this code: https://code.sololearn.com/WxPrU6BqHUy8/#html In which I'm playing with the prototype property of any object (in my case, it is String object). So, when I try to declare a method named "Length" which does nothing, but returns length property; then I sometime got 0 (in sololearn/Play) and sometime an error: "this is undefined" in MDN Demo. I'm having trouble in passing the String object "str" inside its own Length method. But, in JavaScript, `this` is window object, so that's getting passed into the method. How do I resolve this? PS: I've tried using .call and .apply method, but it didn't worked out :/
4 Answers
+ 12
Instead of using the ES6 arrow function, just use the function keyword:
String.prototype.Length = function() {
return this.length;
}
The problem is ES6 arrow functions bind the [this] keyword to the parent context of the arrow function at the time of assignment.
When String.prototype.Length = () => {...} is called, the parent context is actually [window], not [String].
DISCLAIMER:
This is how I understand it from memory at the moment. I may need to confirm my handle on this explanation. đ
+ 10
Follow up : I've put together a quick test script to validate my explanation regarding the sticky binding behavior of ES6 arrow functions.
https://code.sololearn.com/WPEe16x60oV1/?ref=app
I hope my console log notes make sense.
+ 8
You should not use arrow function for prototype function.
Try this
String.prototype.Length = function () {
return this.length;
};
In prototype function, 'this' is the calling object, not window object.
+ 5
Thanks David and Calvin. I got my problem solved \o/