The Module Design Pattern in JavaScript: Explained with Examples

The module design pattern in JavaScript allows you to divide your code into independent parts, promoting well-structured code. We’ll show you how it works.

In the world of JavaScript programming, modules are the order of the day when it comes to keeping parts of your code independent of other components. This promotes loose coupling and ensures well-structured code.

For those familiar with object-oriented programming languages, modules are akin to “classes” in JavaScript. One of the many benefits of classes is called “encapsulation,” which involves protecting states and behaviors from access by other classes. The module pattern enables both public and private access levels.

Modules should be created as “Immediately-Invoked Function Expressions” (IIFE) to enable private scopes. This means that variables and methods are protected, and an object is returned instead of a function. Here’s an example:

        (function() {
            // Declare private variables and/or functions
            return {
                // Declare public variables and/or functions
            }
        })();


In this example, private variables and/or functions are declared first before returning the object. Code outside of our closure cannot access these private variables since it’s not in the same scope.

Let’s illustrate this with a concrete implementation:

        var HTMLChanger = (function() {
            var contents = 'Contents';

            var changeHTML = function() {
                var element = document.getElementById('attribute-to-change');
                element.innerHTML = contents;
            }

            return {
                callChangeHTML: function() {
                    changeHTML();
                    console.log(contents);
                }
            };
        })();

        HTMLChanger.callChangeHTML();       // Outputs: 'Contents'
        console.log(HTMLChanger.contents);  // undefined


Note that `callChangeHTML` is bound to the returned object and can be referenced within the HTMLChanger namespace. However, you cannot access `contents` outside of the module.

Revealing Module Pattern

A variation of the module pattern is known as the “Revealing Module Pattern.” Its purpose is to maintain encapsulation while exposing specific variables and methods returned within an object literal. The direct implementation looks like this:

        var Exposer = (function() {
            var privateVariable = 10;

            var privateMethod = function() {
                console.log('Inside a private method!');
                privateVariable++;
            }

            var methodToExpose = function() {
                console.log('This is a method I want to expose!');
            }

            var otherMethodIWantToExpose = function() {
                privateMethod();
            }

            return {
                first: methodToExpose,
                second: otherMethodIWantToExpose
            };
        })();

        Exposer.first();        // Output: This is a method I want to expose!
        Exposer.second();       // Output: Inside a private method!
        Exposer.methodToExpose; // undefined


While this looks cleaner, an obvious drawback is that private methods cannot be accessed. This can pose challenges in unit testing. Similarly, the public behaviors are not overridable.

Overall, JavaScript modules and the Revealing Module Pattern provide a powerful way to organize and protect your code. Choose the model that best suits your requirements and benefit from better-structured and maintainable code. MongoDB Security Best Practices for Network Access Control Explained with Examples

Create a Free Account

Register now and get access to our Cloud Services.

Posts you might be interested in:

centron Managed Cloud Hosting in Deutschland

How To Set Up a New TypeScript Project

JavaScript
How To Set Up a New TypeScript Project Content1 Introduction2 Table of Contents3 Prerequisites4 Step 1 — Starting the TypeScript Project5 Step 2 — Compiling the TypeScript Project6 Step 3…
centron Managed Cloud Hosting in Deutschland

How To Add JavaScript to HTML

JavaScript
How To Add JavaScript to HTML Content1 Introduction2 Add JavaScript to HTML3 Working with a Separate JavaScript File4 Conclusion to Add JavaScript to HTML Introduction JavaScript, also abbreviated to JS,…