I built this template with all the tools I use in my own personal projects, in order to have a solid starting point for new projects, and hopefully for other developers to benefit from it. I did my best to build the skeleton of what I think is a solid website with proper accessibility, SEO, performance etc.
You can see this template in action on my photography portfolio.
Be aware that this template might quickly become out of date because the web is moving fast !
My side projects are simple public websites, mostly static, with a few simple APIs (contact, fetch data...). This template is optimized for this kind of project.
If you are starting something more complex that needs a full backend with database, authentication etc, I suggest that you give a look at sidebase.
Core
- Nuxt 3, powered by Vite and Nitro (among others), auto-imports, API routes
- State management with Pinia stores
- VueUse functions
- Sass theme, functions and mixins for common use cases
Performance
- Hybrid rendering: combination of SSG and SSR depending on the routes
- Cache-Control header pre-configured on API and SSR routes using a Nuxt server middleware
- Self-hosted fonts using Fontsource
- 100% Lighthouse score on desktop, 97 on mobile
Static checks
- Typescript everywhere
- eslint, prettier
- pre-commit hook for lint and format
Testing
- E2e tests on multiple browsers, desktop and mobile, using Playwright
- Script that fetches the API data and stores it in local files in order to run the app in "mock" mode. It is used for the e2e tests but can be run in standalone, for offline development for instance.
i18n
- multiple languages support with the @nuxtjs/i18n module
- language switch
- automatic language detection and redirection using Vercel Edge Middleware
- meta and link tags for SEO (
og:locale
,hreflang
...)
SEO
- meta tags automatically setup for all pages, using titles and descriptions from translation files
- robots.txt, sitemap.xml
Accessibility
- accessible navigation provided by default for desktop and mobile
- 'Skip navigation' link for keyboard users
CI / CD
- GitHub Action workflow pre-configured on PRs and main branch to run all static checks and tests
- Ready to deploy on Vercel (see the Deployment section below)
Analytics
- integration of Plausible, which is the only paid service here: you can use something else (or nothing at all), but I chose this one because it is GDPR compliant without the need for a cookie banner, it has a lightweight script, a nice clean UI with only relevant data, and unlimited data retention.
Using GitHub
Click on the button 'Use this template' at the top of this page.
Please check 'Include all branches' in order to have the starter branch, which is the pristine template without the demo and documentation.
Using your terminal
Fetch the starter branch without all the git history:
npx degit jsulpis/nuxt3-template#starter your-project
cd your-project && pnpm install
Start the development server with hot module replacement:
pnpm dev
Start in mock mode:
pnpm dev:mock
See the other scripts in the package.json
.
You can connect Vercel and GitHub to deploy each branch and pull request to their own environment, and the main branch in production:
Note that you should be able to deploy this template on another cloud provider (Nuxt 3 supports a lot of them), but you will have to do the redirection of the users based on their language, which is currently implemented with Vercel Edge Middleware.
Check out the deployment documentation for more information.
Released under the MIT license.
Although you don't have to, if you reuse this template for your projects I would appreciate if you would add a little note like 'Nuxt 3 template by @jsulpis' in your footer. Thanks !