Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Modular Programming with JavaScript

You're reading from   Modular Programming with JavaScript Modularize your JavaScript code for better readability, greater maintainability, and enhanced testability

Arrow left icon
Product type Paperback
Published in Jul 2016
Publisher Packt
ISBN-13 9781785880650
Length 274 pages
Edition 1st Edition
Languages
Arrow right icon
Toc

Table of Contents (12) Chapters Close

Preface 1. What Are Modules and Their Advantages? FREE CHAPTER 2. Review of Important JavaScript OOP Concepts 3. Module Design Pattern 4. Designing Simple Modules 5. Module Augmentation 6. Cloning, Inheritance, and Submodules 7. Base, Sandbox, and Core Modules 8. Application Implementation – Putting It All Together 9. Modular Application Design and Testing 10. Enterprise Grade Modular Design, AMD, CommonJS, and ES6 Modules Index

Implementing module augmentation


Imagine that we have a module called ModuleA and, as a developer, you want to add more functionality to this module. However, for some reason, you decide to implement this new functionality in a completely separate module and then dynamically augment the original module with all the data and capabilities of this new module. You can achieve this as shown here:

var ModuleA = (function(coreModule){
    var someData = "this is some data to be used later";
    coreModule.someMethod = function(){
        return someData;
    };

    return coreModule;
})(ModuleA);

As you can see, we are again using the module pattern here, as the intent is to add the new functionality in a modular fashion.

In this IIFE, a reference to coreModule object is returned. There is, however, one important thing to keep in mind here. We are passing ModuleA as a parameter to our anonymous container function. Also, the property someMethod is being added to the passed-in coreModule, which is...

lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image