- Published on
Integrating Contentful with Vite and Vue 3
- Authors
- Name
- Federico Orlandau
- @fedeorlandau
data:image/s3,"s3://crabby-images/9b287/9b287ef8950be91ab06eb550049cb7fd345d77b0" alt="contentful vite"
Motivation
The last Jamstack Community Survey positioned Contentful as one of the favorite CMS for developers. Unlike other CMS, Contentful provides a Community License to work on personal sites, hackathons, or philanthropic projects.
Table of Contents
Getting started
Today, we're going to build a small website with Vue 3 and integrating it with Contentful. The idea is to model a component in Contentful and render it with Vue 3.
Setting up your Vite project
npm init vite@latest
Follow the instructions. Please name your project and select vue
as a framework.
Finally, go into the new folder, install the dependencies and run the solution.
npm install
npm run dev
This will serve a new website on localhost:3000
with the following default view.
data:image/s3,"s3://crabby-images/8ae3c/8ae3cf0a50df1c5936c04150a7da29e76660e048" alt="vue"
Modeling a component in Contentful
For this example, we're going to create a Hero content-type in Contentful.
Hero
content-type ID: hero
- Title, short text. This will be entry title.
- Field ID:
title
- Field ID:
- Description, short text.
- Field ID:
description
- Field ID:
- CTA Text, short text.
- Field ID:
ctaText
- Field ID:
- CTA Link, short text.
- Field ID:
ctaLink
- Field ID:
Your Contentful model should look like this:
data:image/s3,"s3://crabby-images/28640/2864016c6f8c25b9ca3e9df74d72c3c24a29aa3e" alt="hero model"
Creating an entry
Now that we have our Hero content-type created we need to create at least one entry for that model. Just fill in the inputs and publish the entry on the CMS.
data:image/s3,"s3://crabby-images/54c89/54c89f0617feff00f8b561e4072b09af1ee15527" alt="hero entry"
Installing the Contentful SDK into the project
Contentful provides a JS SDK to fetch information from the CMS. You can find it in their GitHub
Let's install the dependency.
npm install contentful
Now, create a new file called contentful.js
in src/
import * as contentful from 'contentful'
const client = contentful.createClient({
space: "YOUR_SPACE",
accessToken: "YOUR_ACCESS_TOKEN"
});
export default client
Remember to replace YOUR_SPACE
AND YOUR_ACCESS_TOKEN
with your Contentful keys.
Building our first component
On the src/components
folder create a new file called Hero.vue
<script setup>
import client from "../contentful";
const res = await client.getEntries({ content_type: "hero" });
const item = res.items[0];
const hero = {
title: item.fields.title,
description: item.fields.description,
ctaLink: item.fields.ctaLink,
ctaText: item.fields.ctaText,
};
</script>
<template>
<div>
<h1>{{ hero.title }}</h1>
<h2>{{ hero.description }}</h2>
<a :href="hero.ctaLink">{{ hero.ctaText }}</a>
</div>
</template>
This component will use Contentful's client to fetch the entries with the hero
content-type.
Now it's time to place this component into the App.vue
<script setup>
import Hero from "./components/Hero.vue";
</script>
<template>
<Suspense>
<Hero />
</Suspense>
</template>
An this is how it looks on the browser:
data:image/s3,"s3://crabby-images/32974/329746bfd6a6a6d6f7703097cd1fe533df5c77df" alt="render entry"
Congratulations! Now you're serving your Contentful entries with Vue 3. You can find the working example with Tailwind CSS here
data:image/s3,"s3://crabby-images/c6a02/c6a028e09e46a7de23e86c50cb8f6c58a2fa1c2b" alt="preview"