Game Instructions

Tap a tile to toggle its color. When a tile changes nearby tiles may change as well. Each move affect multiple tiles. The target is to turn all tiles into yellow in the fewest steps possible.

Press 'j' to show/hide the game. Press 'i' to show/hide the instructions. Press 't' to show/hide the top score table.

Steps: 0

Top Scores

Name Steps
Press J to toggle the game, I to toggle instructions, and T to toggle the top scores

Congratulations!

You solved the puzzle in 0 steps!

Success!

Score submitted successfully!

Error

Failed to submit score. Please try again.

The Decorator Design Pattern in JavaScript PRO

The decorator design pattern was created in order to allow us adding new functionality to an already existing class without extending it. The decorator design pattern was created for those cases in which we cannot extend the class.

The following code sample shows a simple demo for implementing the decorator design pattern in JavaScript.

<!DOCTYPE html>
<html>
<head>
    <title>decorator design pattern demo</title>
</head>
<body>
    <script type="text/javascript">
        function Teacher( options) {
            this.hourRate = options.hourRate || 100;
            this.firstName = options.firstName || "no first name";
            this.lastName = options.lastName || "no last name";
            this.id = options.id || "-9999999999";
            this.subject = options.subject || "history";
        }
        var ob = new Teacher({
            hourRate:200,
            firstName:"haim",
            lastName:"michael",
            id:242332434,
            subject:"Java"
        });
        //decorating our object with new functionality
        ob.salary = function(hours) {return hours*this.hourRate;};
        document.write(ob.salary(150));
    </script>
</body>
</html>

The following video clip goes over the code, shows its execution and explains it in detail.

You can find more video clips, training material and code samples for learning about the available design patterns in JavaScript in my free online courses website at http://abelski.lifemichael.com.

Share:

The Beauty of Code

Coding is Art! Developing Code That Works is Simple. Develop Code with Style is a Challenge!

Update cookies preferences