Back to Courses
AI020 Professional

Eloquent JavaScript: A Modern Introduction to Programming

A comprehensive guide to modern programming using JavaScript. The course covers fundamental programming principles, the JavaScript language specification, web browser integration, and server-side development with Node.js, including five real-world project applications.

5.0
30.0h
561 students
0 likes
Artificial Intelligence
Start Learning

Lessons

Lesson

This lesson introduces the concept of programming as the art of subduing complexity by creating immaterial logic that directs physical hardware. Students will learn the fundamental structure of JavaScript, including the roles of variables, control flow, and the distinction between statements and expressions.

This lesson explores advanced control flow in JavaScript, focusing on sophisticated iteration patterns like for loops, do-while loops, and multi-way branching with switch statements. Students will learn to manage program execution precisely using break and continue keywords, modular arithmetic, and nested loops to solve complex algorithmic challenges.

This lesson explores the concept of abstraction in programming, focusing on how to transition from imperative, hardware-level logic to declarative, human-readable code. Students will learn to implement and refine flexible functions, such as range and sum, while analyzing the performance trade-offs associated with the abstraction tax.

This lesson explores interface-based polymorphism by defining a standardized Table Interface that allows layout engines to process diverse data types through a consistent set of methods. Students will learn to implement flexible, decoupled systems by using defensive programming techniques and interface contracts to manage object rendering and alignment.

This lesson introduces Regular Expressions (RegExp) in JavaScript, covering how to define patterns using literal notation or constructors and how to use the .test() method for validation. Students will learn to manage case sensitivity, handle special characters through escaping, and apply these techniques to dynamic string matching tasks.

This lesson explores the evolution of JavaScript module systems, focusing on how to prevent namespace pollution through techniques like Immediately Invoked Function Expressions (IIFEs) and closures. Students will learn to design robust, encapsulated code by creating private scopes and structured public interfaces for their modules.

AI020: Events and Interactive Platforms (Lesson 7) explores the technical foundations of building dynamic web experiences through DOM manipulation, regular expressions, and event handling. Students will learn to transform static content into interactive environments by implementing efficient workflows for real-time feedback and user input tracking.

This lesson explores the performance advantages of the HTML5 Canvas API over SVG for high-density graphics by utilizing a 2D rendering context to bypass DOM overhead. Students will also examine the role of the transport layer in web applications, specifically analyzing the performance trade-offs between TCP and UDP for data transmission.

This lesson explores the necessity of asynchronous programming in web development to prevent UI freezing caused by synchronous I/O operations. Students will learn to implement event-driven patterns and browser persistence APIs to maintain responsive, high-performance applications during network-intensive tasks.

This lesson explores advanced Canvas API techniques for building interactive drawing tools, focusing on state management, composite operations, and mathematical constraints. Students will learn to implement dynamic features like spray brushes and erasers by manipulating canvas context properties and handling mouse events through higher-order patterns.

Course Overview

📚 Content Summary

A comprehensive guide to modern programming using JavaScript. The course covers fundamental programming principles, the JavaScript language specification, web browser integration, and server-side development with Node.js, including five real-world project applications.

A deep and elegant dive into the heart of JavaScript programming.

Author: Marijn Haverbeke

Acknowledgments: Supported by 454 financial backers; illustrations by Wasif Hyder, Max Xiantu, Margarita Martínez, José Menor, Jim Tierney, Dyle MacGregor, Jeff Avallone, Thomas Palef, and Antonio Perdomo Pastor.

🎯 Learning Objectives

  1. Define what a program is and explain the different levels of abstraction in computer languages.
  2. Utilize JavaScript numbers and arithmetic operators to produce values.
  3. Declare and update variables while adhering to naming conventions and reserved word restrictions.
  4. Implement robust control flow using do loops, for loops, and switch statements while maintaining clean code via indentation and comments.
  5. Define and invoke functions using multiple notations, handling parameters, optional arguments, and nested lexical scopes.
  6. Apply advanced functional concepts such as recursion, closures, and the call stack to solve complex algorithmic puzzles.
  7. Utilize specialized object and array methods to manage complex data structures and strings.
  8. Implement higher-order functions (filter, map, reduce) to abstract logic and compose data transformations.
  9. Navigate and manipulate the prototype chain to create structured, reusable object instances and polymorphic interfaces.
  10. Implement polymorphic interfaces to handle complex data visualization (tables).

Lessons