In this two-part series, I’m going to cover How to create blog using NuxtJS and NetlifyCMS.

Getting started

Creating NuxtJS app

To set up a blog with NetlifyCMS all you need is a Netlify and a GitHub (or GitLab or Bitbucket) account.

Create a NuxtJS app using create-nuxt-app

npx create-nuxt-app <app-name>

cd <app-name>

npm run dev

Setting up NetlifyCMS

In static directory add a new directory named admin and add an HTML file named index.html with the following content -

<!DOCTYPE html>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Content Manager</title>
    <!-- Include the script that enables Netlify Identity on this page. -->
    <script src=""></script>
    <!-- Include the script that builds the page and powers Netlify CMS -->
    <script src="^2.0.0/dist/netlify-cms.js"></script>

Add another file named config.yml which contains all the configuration about your model and collections.

  name: git-gateway
  branch: master

media_folder: static/img
public_folder: /img

  - name: "blog"
    label: "Blog"
    format: "json"
    folder: "assets/content/blog"
    create: true
    slug: "{{slug}}"
      preview: true
      - { label: "Title", name: "title", widget: "string" }
      - { label: "Publish Date", name: "date", widget: "datetime" }
      - {
          label: "Featured Image",
          name: "thumbnail",
          widget: "image",
          required: true,
      - { label: "Body", name: "body", widget: "markdown" }

Push the code to GitHub. Now create a new website on Netlify using your GitHub so that whenever you push to the repository Netlify will automatically fetch the new content from the repo and build the latest version of your website, this is called Continuous Deployment.

Enable Identity & Git Gateway in Netlify

To access the CMS you need to enable authentication in your netlify website. Go to your netlify dashboard and select the website you have created.

  1. Go to Settings > Identity and Enable Identity service. step-1
  2. After enabling, go to Identity>Registration, set this option to open or invite. Usually, invite is the best option if you are the only person writing blogs on the website. You can also enable external providers like Google, GitHub, etc for authentication if you don’t want to create an account. step-2
  3. Go to Identity>Services and click Enable Git gateway step-3

Now go to https://<your-website> you’ll be prompted to log in. Create your account and set the registration option to invite-only (as in step 2). Log in with your credentials and create a new blog post and publish it.

Now do a git pull to fetch the latest posts from the repository. You can find the blogs in the assets/content/blog directory of your project.

In the next part, we’ll see how to integrate the content in NuxtJS to show on the website.

I have also created a repository to get you started with the NuxtJS blog.