CSS for JavaScript Developers vs Complete Intro to Containers (feat. Docker)
Same Bayesian formula, same rubric — so the difference in scores reflects the difference in the courses, not the difference in how we evaluated them.
Frontend Masters · Web Development
CSS for JavaScript Developers
Frontend Masters · Web Development
Complete Intro to Containers (feat. Docker)
Per-criterion
The course covers all major CSS layout algorithms — flow, positioned, flexbox, grid — plus typography, animations, custom properties, and advanced polish techniques across 10 modules and 200+ lessons. Rather than cataloguing properties, Josh builds mental models for how each layout mode reasons about space, which multiple reviewers describe as "mastery level" coverage. The December 2025 update added subgrid and reading-flow content, keeping the curriculum current. The depth and pedagogical structure place it above any free alternative for developers who want to understand CSS rather than memorise it.
Josh W. Comeau is the most consistently praised CSS educator in independent developer communities. His personal blog (joshwcomeau.com) is cited as a reference-quality resource on its own, and the course extends that same standard of clarity into interactive format. Endorsements from Adam Wathan (Tailwind CSS creator), Kent C. Dodds (Epic React), and Laurie Barth (Netflix) are not marketing copy — each commenter is themselves a well-known practitioner. The Hacker News thread from October 2021 includes commenters praising his use of mental models such as "media queries as IF statements" as genuinely clarifying rather than simplified.
The course is available standalone on Josh's own platform (css-for-js.dev) with one-time pricing and lifetime access to updates, and also via a Frontend Masters subscription (~$39/month or $390/year). The standalone price has drawn criticism — one Hacker News commenter in 2021 noted paying $418 with taxes and called it "one heck of an expensive course," and another pointed out that the basic tier excludes flexbox and responsive design. For Frontend Masters subscribers who access it as part of a broader library, the value calculation tilts strongly positive. Regional purchasing power parity discounts and occasional sales (Valentine's Day, Black Friday) improve accessibility, but the sticker price remains the main objection in critical reviews.
Each of the 10 modules ends in a workshop — a larger, real-world-inspired project that applies the module's concepts. Students build responsive layouts, polished UI components from Figma mockups, custom form controls, and animated interactions. The interactive exercises and mini-games within lessons are consistently praised for building intuition rather than just testing recall. One reviewer's only complaint was being required to use Styled Components and React in workshops rather than their preferred tools — a minor friction point in an otherwise well-designed project sequence that demonstrates real production patterns.
The course is explicitly designed for developers working in React, Vue, or Angular component architectures, and the examples reflect production patterns rather than academic exercises. Multiple reviewers with years of professional experience report that the course changed how they reason about CSS in daily work — "less guesswork" and "more efficient" are the recurring phrases. Noel De Martin, a developer with 10+ years of experience, called it "the best course I've ever taken" and said it "should be mandatory for anyone working in the frontend." The coverage of CSS-in-JS, CSS variables, and component-level architecture maps directly to current React/Vue production workflows.
The course stands apart from typical Docker tutorials by opening with a module called "Crafting Containers by Hand," where students manually implement chroot, Linux namespaces, and cgroups before Docker is introduced. This first-principles approach is the most-cited reason learners say the course made containers finally click, rather than just memorising Dockerfile syntax. The curriculum then progresses through Docker images, Dockerfiles, Node.js containerisation, layer caching strategies, Alpine Linux for smaller images, multi-stage builds, distroless containers, static asset optimisation, bind mounts, volumes, dev containers, Docker networking, Docker Compose, and a practical introduction to Kubernetes and Kompose. The open-source companion notes at btholt.github.io/complete-intro-to-containers are freely available under a Creative Commons licence, which allows learners to revisit content without re-watching videos. The course does cover the original version's content well; a v2 update on Frontend Masters addresses cgroups v2 changes and dependency freshness, so learners should verify which version they are accessing. Minor critiques include the relative brevity of the Kubernetes module, which is treated as a brief orientation rather than a deep dive, and the Node.js-heavy examples, which assume JavaScript familiarity even though the container concepts themselves are language-agnostic.
Brian Holt brings over a decade of engineering and product management experience across Netflix, LinkedIn, Reddit, Microsoft (VS Code team), Stripe, Snowflake/Streamlit, and Databricks, giving him genuine production-grade context for every concept he teaches. On Frontend Masters, he has authored more than a dozen "Complete Intro" courses, making him one of the platform's highest-volume and most-reviewed instructors. Learner feedback consistently uses the same descriptors across multiple courses and years: "excellent," "clear," "fun," "great teacher." His containers course specifically is praised for making systems-level Linux concepts approachable to web developers who have never opened a man page. Holt openly acknowledges when a topic is dense — he describes the course as "pretty dense with a lot of systems-level stuff thrown at you in a short time" — but frames each piece incrementally so the cognitive load stays manageable. His tendency to explain the why behind each tool (why cgroups exist, why Alpine saves hundreds of megabytes, why distroless containers matter in CI/CD pipelines) is cited by multiple reviewers as what separates this from documentation-style instruction. The only consistent criticism is that his pace can feel quick for learners coming from a pure frontend background with no prior Linux exposure, and those learners are advised to take his Complete Intro to Linux and the Command-Line first.
Access to the course requires a Frontend Masters subscription, priced at $39 per month or $390 per year (effectively $32.50 per month). The subscription model is the most common source of neutral and negative sentiment across the 38 opinions analysed, as it compares unfavourably to a one-time Udemy purchase for learners who only want a single course. The value calculation improves significantly if the learner is already subscribed for other Frontend Masters content or plans to take additional courses in the same month. Within that framing, reviewers consistently describe the subscription as worthwhile given the breadth and depth of the catalog. The course notes for Complete Intro to Containers are freely published on GitHub and btholt.github.io under a Creative Commons licence, which Holt explicitly designed so that financial barriers do not block access to the curriculum. Learners on a tight budget can follow the full written curriculum for free, losing only the video walkthroughs. Several blog posts note that this free-access policy, combined with the open-source code examples, makes the course more transparent than most paid offerings at a similar price point.
Rather than a single end-to-end application, the course uses a progression of hands-on exercises that directly reinforce each module. Students begin by creating a containerised environment entirely from Linux primitives — chroot, unshare, cgroups — using command-line tools directly in the terminal. Subsequent exercises containerise a real Node.js application, iterating through progressively optimised Dockerfiles: first a basic image, then one with explicit layer ordering for faster rebuilds, then an Alpine-based version that is roughly 80% smaller than the Debian default, then a multi-stage build, then a distroless variant. The Docker Compose module adds a MongoDB service alongside the Node app, creating a practical multi-container scenario that mirrors real development setups. Pre-built Docker images are provided so that slow internet connections do not block workshop progress. Reviewers note the exercises feel production-relevant rather than toy examples, and the GitHub repository (945 stars, 181 forks) demonstrates ongoing community use. The Kubernetes exercises are more abbreviated — primarily using Kompose to convert a Compose file — and learners who want deep Kubernetes practice will need a dedicated course afterwards.
Container knowledge has become a baseline expectation for full-stack and backend developers at most organisations that deploy to the cloud, and this course maps directly to the most common production patterns: writing Dockerfiles for Node.js services, reducing image sizes for faster CI/CD pipelines, using multi-stage builds to separate build and runtime environments, structuring multi-service applications with Docker Compose, and understanding how Kubernetes orchestrates containers at scale. The dev containers module is particularly relevant to modern team workflows, covering how to use containers to create reproducible development environments that eliminate "works on my machine" problems. Holt draws on his experience across Netflix, Reddit, and cloud infrastructure roles at Stripe and Databricks to ground each concept in how it is actually used in production. Multiple blog post reviewers describe going directly from the course to containerising services at work. The Kubernetes coverage is acknowledged as introductory rather than comprehensive, and learners moving into DevOps or platform engineering roles will need further study. For web developers adding Docker competency to an existing JavaScript skill set, however, this is the most practically oriented course in the Frontend Masters catalog.
Scoring methodology applies identically to every course on the site — see the formula.