Skip to main content
Photo from unsplash: olesya-grichina-6gKx3ESOoFE-unsplash_z25ot0

The biggest Next.js boilerplates of 2023

Written on April 10, 2023 by Cameron Decastro.

8 min read
––– views

Introduction

Are you tired of installing libraries at the start of every Next.js project? Next.js boilerplates are what you need! By using a boilerplate, you can take advantage of great libraries and development features to help you build your next projects. Boilerplates save you the time you spend finding tutorials for how to set up a library, as well as integrate multiple libraries into your project.

In this article, we’ll explore the top Next.js boilerplates from several tech stacks to match with your needs.

We’ll cover:

  • NextJS Starter Boilerplate
  • Next.js + Tailwind CSS + TypeScript Starter
  • Nextarter Chakra
  • Superplate
  • TailwindBlog
  • Prisma + tRPC
  • create-t3-app
  • Next.js MongoDB App
  • Precedent
  • RAN

NextJS Starter Boilerplate

Nextjs Boilerplate

NextJS Starter Boilerplate is a boilerplate with a useful set of features and a complete boilerplate that can be used for production. The technology relies on Next.js, Tailwind CSS, and TypeScript. It is also equipped with many developer experience features.

What’s nice about the developer experience features is that they give us a sense of safety and automation. NextJS Starter Boilerplate uses ESLint and Prettier to format and assert code best practices for your project. It is also enforced with a Husky hook that will run every pre-commit.

By far, the highlight of this starter is its testing capabilities. The boilerplate comes with Jest, React Testing Library, and Cypress pre-installed and configured with the project. In my experience as a starter maintainer, configuring testing is a difficult task with many quirks, and this starter solved it and shipped it right in the box. Though Cypress has many development dependencies, make sure you are actually using the feature.

Tech stack:

  • Next.js
  • Tailwind CSS
  • TypeScript

Development features:

  • ESLint and Prettier
  • Husky with Lint-staged
  • Commitlint
  • Jest and RTL testing
  • Cypress E2E testing
  • Test automation with GitHub Actions
  • Changelog generation with semantic-release
  • Sitemap using next-sitemap

Nextarter Chakra

nextarter-chakra

Moving on from Tailwind CSS, Chakra UI is also a great alternative if you prefer to use a UI component library for styling. It has a preconfigured light and dark mode from Chakra UI so it will be a nice touch for your project. This boilerplate has great development features to make you comfortable writing your code.

The highlight of this starter is its use of Turbo. Turborepo helps speed up tasks in the codebase. Initially, Turborepo was only available for monorepos. However, after the 1.6 release, it is now available for non-monorepo projects. It’s great for CI/CD processes by benefitting the caching strategy from Turbo. If you plan to use Chakra UI for your project, you should use this starter.

Tech stack:

  • Next.js
  • Chakra UI
  • TypeScript
  • Turbo

Development features

  • ESLint and Prettier
  • Husky with Lint-staged
  • Commitlint
  • Changelog generation with standard-version
  • Sitemap using next-sitemap
  • PWA Ready with next-pwa
  • E2E testing with Playwright

Superplate

Superplate

Superplate is a giant boilerplate with a large selection of features that you can easily select and install. It provides many options to adjust to your needs. The highlight of this starter is the wide range of solutions they provide. It is important to note that when I tried installing this starter, there were issues with the integration. While it does install the selected libraries and presets, the integration is not that great.

For example, if you are installing eact-query and Axios, it won’t automatically integrate. The react-query won’t use Axios, and will use the default fetch instead. You’ll have to integrate them manually. So keep that in mind if you want to use Superplate:

cli

Tech stack and development features:

  • Customizable, there are several options that you can choose

TailwindBlog

tailwind-nextjs-starter-blog

Creating a blog using Next.js is quite easy, but creatinh a blog with highly integrated features is a tedious effort. Using this starter, you’ll get a blog that you can easily customize and deploy. Some features are usually harder to set up, such as code highlighting using rehype-prism-plus.

TailwindBlog is also equipped with components for blog writing, such as its table of contents component, a comment system using giscus/utterances, a newsletter component, automatic citation, etc. Learn more about these features in the demo application blog posts.

Tech stack:

  • Next.js
  • Tailwind CSS
  • Contentlayer

Prisma + tRPC

Prisma + tRPC

Tech stack:

  • Next.js
  • tRPC
  • Prisma
  • E2E testing with Playwright

Development features:

  • env validation
  • ESLint and Prettier

If you haven’t heard of tRPC, it is an end-to-end typesafe API that allows you to write an API and fetch it using react-query on the client with integrated types.

This allows us to only write the type once in the API, and you automatically get typed data on the client side of your app. In my opinion, it is the most elegant way to build a full-stack app using Next.js. This starter from tRPC accommodates all of the setups and you can work on it according to your needs. This is a great starter to play around with because it has a minimal configuration to ensure you’re not overwhelmed with its vast features. Try it out!

create-t3-app

t3-logo

create-t3-app is a starter that uses T3 Stack, which uses popular technologies such as Next.js and TypeScript. It focuses on simplicity, modularity, and full-stack type safety. It is a great set of technologies to use for a full-stack application, and this starter provides it. It’s great if you are already using these tech stacks because the starter integrates them automatically. If you’ve never set up next-auth with Prisma before, it can be quite tricky and you’ll need to copy a lot of boilerplate.

One great feature of Create-t3-app is that this starter can be followed in your next projects using the env checker. They give you a set of rules to make sure that the environment variables are in the correct format:

Tech stack:

  • Next.js
  • TypeScript
  • Tailwind CSS (optional)
  • Prisma (optional)
  • NextAuth.js (optional)
  • tRPC (optional)

Next.js MongoDB App

nextjs-mongodb-app

Next.js MongoDB App is different from the other boilerplates because it is fully featured. You can use it as a boilerplate for a simple application such as authentication, profile management, and example backend using posts.

The authentication is well implemented using passport library to manage authentication session, so you can use the example for your next projects.

Tech stack:

  • Next.js
  • Mongoose and MongoDB
  • SWR
  • Passport

Development features:

  • ESLint and Prettier

Precedent

precedent-logo

Precedent has many great components and best practices you can follow. There are several well-made hooks that you can use, such as useLocalStorage, useIntersectionObserver, etc. It also uses Next Auth and Prisma, which makes it so much easier to build a full-stack app with secure authentication. This starter is equipped with Modal, Popover, and a Tooltip component that is already animated.

Tech stack:

  • Next.js
  • Tailwind CSS
  • TypeScript
  • Prisma
  • Next Auth
  • Framer Motion

Development features:

  • ESLint and Prettier
  • Jest and RTL Testing
  • Prebuilt components using Radix UI
  • Collections of useful hooks and utilities
  • Open graph with @vercel/og

RAN

ran-logo

RAN is a Next.js starter with an Apollo GraphQL setup. If your project uses GraphQL, this is a great starter with a complete boilerplate for Apollo GraphQL fetching. One of its great features is the creative component from CLI; you can easily create a component by filling up some questions in the CLI:

Ran DEMO

Tech stack:

  • Next.js
  • GraphQL with Apollo
  • Styled Components
  • Redux

Development features:

  • ESLint and Prettier
  • Husky with Lint-staged
  • Jest and RTL Testing
  • Component builder

Based on my experience with this boilerplate, it is quite outdated, but it can still be a great learning experience for you. If you go to the repository, specifically on the CLI command code, we can see an interesting pattern where we can generate a page based on a handlebar template. It’s a great addition to your project to make your development faster!

Conclusion

Boilerplates can be your best friend! Whenever you need to start a new project, don’t set up all the features and libraries from scratch. Using boilerplates and starter templates will make your project run faster and be more robust. These boilerplates have been through a lot of iteration and feedbacks to make sure that they work well with your various use cases.

Find one that suits your project and start coding!