CourseVerdict

Build Responsive Real-World Websites with HTML and CSS 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.

Udemy (Jonas Schmedtmann) · Web Development

Build Responsive Real-World Websites with HTML and CSS

4.6/ 5 · 25 opinions
19 positive4 neutral2 negative/ 25 total

Frontend Masters · Web Development

Complete Intro to Containers (feat. Docker)

4.5/ 5 · 38 opinions
28 positive6 neutral4 negative/ 38 total

Per-criterion

Content quality4.6 / 5

The curriculum covers modern HTML5, CSS Flexbox, CSS Grid, the box model, positioning, selector conflicts, and a complete seven-step professional development process (plan, sketch, design, build, test, optimize, launch). A dedicated section on web design principles — typography, color, spacing, imagery — is consistently singled out as rare among HTML/CSS courses and genuinely useful. The course was rebuilt in 2021 and updated through November 2024, keeping it current. The main structural critique is that floats are used in the major Omnifood project even though Flexbox and Grid are taught, with the modern layout systems introduced late in the course.

Instructor4.5 / 5

Jonas Schmedtmann is consistently named one of the top three Udemy instructors alongside Andrew Mead and Maximilian Schwarzmüller, with over 1.3 million total enrolled students. Learners praise his clear, structured explanations and his ability to make complex topics accessible without being superficial. As with his other courses, a minority of learners flag a deliberate, measured pacing that works best at 1.5x speed. Within HTML and CSS instruction specifically, reviewers single out his design-eye as a differentiator — he teaches how to make things look good, not just how to make them work.

Value for money4.8 / 5

Listed at $119.99 but routinely available for $9–$15 on Udemy sales. At sale price, 37.5 hours of video, 10+ coding challenges, lifetime access, and a portfolio-ready final project make this one of the strongest content-per-dollar ratios in front-end instruction. With 431,920 students enrolled and a 4.7 average across 109,000+ ratings, it carries more social proof than almost any other HTML/CSS offering on the market. One learner called it "best $20 I spent in my life." No reviewer recommends paying full price; waiting for a sale is the standard advice.

Projects4.5 / 5

The flagship project — Omnifood, a complete responsive landing page for a fictional healthy meal delivery startup — is the most-cited strength in learner testimonials. It is portfolio-ready, available live at omnifood.dev, and teaches the full development lifecycle from planning through launch. Ten additional coding challenges reinforce each concept section. The one recurring caveat is that the main project leans on floats for layout rather than demonstrating the Flexbox and Grid patterns that professionals now use day-to-day, which is an inconsistency for learners who want to build from modern foundations from the start.

Real-world use4.4 / 5

Strong real-world alignment via the design-principles section, the professional workflow walkthrough, and the guidance on sourcing free design assets (images, icons, fonts). Learners consistently report being able to apply skills immediately — multiple reviewers describe building client or work projects within days of completing sections. The course stops short of JavaScript interaction, component architecture, or modern deployment workflows, so it is a strong foundation rather than a complete job-readiness package. Most learners pair it with the same instructor's JavaScript course next.

Content quality4.5 / 5

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.

Instructor4.7 / 5

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.

Value for money4.2 / 5

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.

Projects4.3 / 5

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.

Real-world use4.6 / 5

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.