This template includes a Nuxt app with a Sanity Studio – an open-source Vue application that connects to your Sanity project's hosted dataset. The Studio is configured locally and can then be deployed for content collaboration.
- Nuxt 3 for Performance: Leverage the power of Nuxt 3's hybrid rendering capabilities for blazing-fast performance and SEO-friendly applications.
- Real-time Previews: Edit content live with Sanity's Presentation Tool and see updates in real time.
- Powerful Content Management: Collaborate with team members in real-time, with fine-grained revision history.
- AI-powered Media Support: Auto-generate alt text with Sanity AI Assist. (Available on Free Trial and Growth Tiers. See Pricing)
- Flexible Rendering Strategies: Choose between Server-Side Rendering (SSR), Static Site Generation (SSG), or hybrid rendering at the route level.
- Easy Media Management: Integrated Unsplash support for seamless media handling.
https://template-nuxt-clean.sanity.dev
Run the command in your Terminal to initialize this template on your local computer.
See the documentation if you are having issues with the CLI.
npm create sanity@latest -- --template sanity-io/sanity-template-nuxt-clean
(ToDo: update script when merging)
Navigate to the template directory using cd <your app name>
, and start the development servers by running the following command
npm run dev
Open the Nuxt app running locally in your browser on http://localhost:3000.
Open the Studio running locally in your browser on http://localhost:3333. You should now see a screen prompting you to log in to the Studio. Use the same service (Google, GitHub, or email) that you used when you logged in to the CLI.
The template comes pre-defined with a schema containing Page
, Post
, Person
, and Settings
document types.
From the Studio, click "+ Create" and select the Post
document type. Go ahead and create and publish the document.
Your content should now appear in your Nuxt app (http://localhost:3000) as well as in the Studio on the "Presentation" Tab
You may want to start with some sample content and we've got you covered. Run this command from the root of your project to import the provided dataset (sample-data.tar.gz) into your Sanity project. This step is optional but can be helpful for getting started quickly.
npm run import-sample-data
The schema for the Post
document type is defined in the studio/src/schemaTypes/post.ts
file. You can add more document types to the schema to suit your needs.
Your Nuxt frontend (/frontend
) and Sanity Studio (/studio
) are still only running on your local computer. It's time to deploy and get it into the hands of other content editors.
Back in your Studio directory (/studio
), run the following command to deploy your Sanity Studio.
npx sanity deploy
You have the freedom to deploy your Nuxt app to your hosting provider of choice. Nuxt applications can be deployed to various platforms including Vercel, Netlify, or any platform that supports Node.js or edge runtime.
- Create a GitHub repository from this project. Learn more.
- Choose your preferred hosting platform and follow their deployment guides for Nuxt applications.
- Configure your Environment Variables as needed.
For detailed deployment instructions, visit the Nuxt deployment documentation.
Now that you've deployed your Nuxt application and Sanity Studio, you can optionally invite a collaborator to your Studio. Open up Manage, select your project and click "Invite project members"
They will be able to access the deployed Studio, where you can collaborate together on creating content.