Course Overview
This page covers the overall philosophy and motivations behind the course. For detailed information about grading and policies see the syllabus
Why 61D?
After taking an introductory computer science course, such as Berkeley's CS61A or Harvard CS50, there is no immediately obvious next step a student should take to learn how to build a modern full stack application from design to deployment. Knowledge of functions, conditionals, loops, recursion, and even complex data structures is not enough to actually create and launch a web application. Even after a full computer science degree, there is no guarantee that a student will ever interact with a database, a web server, build any kind of user interface, or deploy to more than an autograder.
This course bridges that gap. Designed to be taken after a first-semester university-level computer science course, 61D teaches an opinionated set of technologies which are widely used in industry to build full stack applications. The course is designed to be taken in a single semester, and is structured to be accessible to students with no prior experience in web development. All course materials will be open source and free forever. Our goal is to be the default next step all aspiring software engineers take when learning how to build full stack applications.
Technologies We Cover, and Why We Chose Them
The technologies used in the course are inspired by the t3 stack. All technology choices have tradeoffs, but we believe our choices provide the best set of tradeoffs for a student looking to get developing quickly without taking shortcuts. Most importantly, the stack is a complete solution for building web applications. All of the individual parts mesh well together, and there are no black boxes or missing layers of connective tissue.
-
Move quickly, break nothing: The t3 stack has a cli tool which can be used to scaffold a project in seconds. End to end typesafety is the built in.
-
Use standard open source tools: We teach only open source industry standard tools. You are never at risk of vendor lock in with the t3 stack. Further, there is a rich ecosystem of resources and guides online teaching the various components of the stack.
-
Prioritize developer experience: The t3 stack is a joy to code with. The tooling and interoperability within the stack lets you code, debug, and ship faster.
-
Fundamentals:
- Git: Industry standard version control.
- JavaScript + TypeScript: The most popular programming language in the world, which is used in all interactive front end applications, and are also widely used in non-performance critical back end applications.
- Developer Productivity: Efficient use of the command line, linters and formatters, the VSCode ecosystem, and basic debugging.
-
Front End:
- React: The most popular industry standard framework for building front ends.
- Tailwind CSS: A modern approach to styling which locates styles inline instead of in a separate file.
- Next JS: The world's most popular React framework which provides the functionality needed to build full stack applications.
- React Query (aka Tanstack Query): Used in one in six of all React applications, React Query is the industry standard way of managing server state in React applications.
- shadcn-ui: Building components completely from scratch in a waste of time for the vast majority of projects. However, typical component libraries often provide minimal options for customization. Shadcn-ui is quickly becoming the default choice for React projects as the source code for all components lives in your codebase.
- React Hook Form: The quickest and easiest way to create controlled and validated forms in react. Works beautifully with zod and shadcn-ui.
-
Back End:
- tRPC: A modern type-safe back end framework.
- zod: The most popular Typescript data validation library used on both the frontend and the backend.
- PostgreSQL with Drizzle ORM: The most popular relational database, with the most modern tool for accessing it.
- Auth.js: Open source authentication library allowing use authentication with any OAuth provider.
- APIs and Webhooks: Subscribing to webhooks and using APIs of external services.
-
Deployment and Infrastructure:
- Managed Deployments with Vercel: Deploy and scale globally with a single command to popular platforms with generous free tiers.
- Self Hosted Deployment with Docker and Coolify: Run you applications on any machine with open source self hostable technologies. Use free cloud credits provided to students to run your applications.
Course Content
Lectures
All course content is covered in a series of 24 lectures, which will be available on our YouTube channel. These lectures will be a mix of covering conceptual concepts, and working through live examples. Most lectures will have a some starter code in a github repository that can be used to follow along with the lecture.
Readings
Combing through YouTube videos to find that one code snippet is tough. Readings provide at a glace cheat sheets and reference for the materials covered in lecture, and useful code snippets which can be copied and pasted directly into your project. They also provide links to other resources to explore further, or cover extra supplemental content not covered in lecture.
Labs
The course will have 12 labs, which are meant to be guided demonstrations and practice of concepts covered in the lectures. These will be held in person, and be the best place to ask questions about course materials and content.
Assignments
All content will be practiced in coding assignments, which will be graded by the course staff or by auto graders. All assignments will come with starter code, and have detailed instructions which hold your hand at first and slowly let you take the reigns. Assignments will range in length and difficulty. The starter code for assignments will be public, and solutions will be available after submission. All assignments will also include a rubric for self grading if you are auditing the course. Assignments include but are not limited to:
- Building a simple frontend todo list with React
- Creating a registration form with input validation using React Hook Form
- Styling a landing page for a travel agency with Tailwind CSS
- Creating a ranked choice voting system with tRPC and Drizzle
- Building a simple blog website with NextJs and shadcn-ui
- Creating an integration with GitHub which automatically leaves comments on pull requests
Projects
The course will have two projects, one smaller front end project, and one final full stack project. The final project will still have guidelines and a specification, but will be much less structured than the rest of the assignments in the course.
-
Create an image format converter which allows you to change the file format of images in the browser.
-
Create a splitwise clone to track and organize shared expenses and repayments.
The name of the course is inspired by the naming of UC Berkeley lower division computer science courses. CS 61A, 61B, and 61C are official courses, and we think that the content our course, 61D, is almost as important!