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? 2. Review of Important JavaScript OOP Concepts FREE CHAPTER 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

Submodules


The last technique that we consider in this chapter, which also allows us to extend our modules, is using submodules.

Submodules are essentially independent modules, which can be added to another module as properties of the hosting module. There are various ways of adding submodules to other modules and we will cover two of these approaches in this section.

Let's stay with the shape theme that we have been using so far and create a Shape module. We will consider this module as our hosting module. This module is the parent module for all 2D and 3D shapes and we will add our Polygon module to it.

Adding submodules using dynamic properties

Adding a submodule to a module as a dynamic property is straightforward, and as we can add dynamic properties to any JavaScript object, we can add a property to a hosting module which points to a submodule.

Consider the following:

var Shape = (function(){
    
        var type = "Any 2D and 3D shape";
    
        function getType(){
            return...
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