Code Organization and the "this" Value in Object-Oriented JavaScript
When organizing JavaScript prototype-based code, a common challenge arises in preserving object references and inheritance. Suppose you have a Carousel class with various functions like next(), prev(), and bindControls(). To enhance code organization, you wish to group these functions under a controls property like so:
Carousel.prototype.controls = { next: function () { ... } , prev: function() { ... }, bindControls: function () { .. } };
However, this approach disrupts the "this" value, which is crucial for accessing object properties and methods. To maintain the "this" value in the original context, you can adopt the following solution:
Create a Controls class, which keeps a reference to the controllable object within the Controls constructor. The method in Controls that handles actions, such as next(), uses the reference to invoke the appropriate method in the controllable object.
var Controls = function (controllable_object) { this.ref = controllable_object; }; Controls.prototype.next = function () { this.ref.foo(); } // .. var Carousel = function () { this.controls = new Controls(this); }; // ..
This ensures inheritance and allows you to override the implementation of Controls through a mechanism like dependency injection.
The above is the detailed content of How Can I Maintain the \'this\' Value When Organizing JavaScript Prototype-Based Code?. For more information, please follow other related articles on the PHP Chinese website!