This guide will walk you through your first steps using Contentful within an Express Node js application. It will provide a step-by-step guide on how to get your first entries and start using the content you create on Contentful.
- A Heroku account
- Heroku CLI installed
- [Node.js] 2 6.2.1 installed
- Npm 3.10.7 which should be installed with Nodejs
- Git installed
- Basic Command Line Interface knowledge
First we'll start with a demo project, which is a simple Express js application using Contentful's 'Product Catalogue' template, so that you can see it running for yourself.
Run the following commands to get started.
- Clone the example repository:
git clone https://github.com/contentful/contentful_express_tutorial.git
- Navigate into the repository's directory:
$ cd contentful_express_tutorial
- Install dependencies:
$ npm install
- Run the server:
$ npm run dev
Everything is now set up. You can view your new data by opening http://localhost:3000/ in your browser.
It should look something like this:
You can create your own custom data by following these steps:
- Create an account with Contentful or Log In.
- Create a new Space with the 'Product Catalogue' template, name it whatever you like.
- Copy the space Id and api key as shown in the screenshot
-
Change the product content type by your own, here. e.g. replacing
2PqfXUJwE8qSYKuM0U6w8M
withproduct
-
Change the category content type by your own, here. e.g. replacing
6XwpTaSiiI2Ak2Ww0oi6qa
withcategory
-
In the Express js application:
- navigate to the package.json file open it and change the values
accessToken
andspace
in theconfig
section and save. - run
npm run dev
to start the server - Your space will be now displayed in your application
- navigate to the package.json file open it and change the values
Next in the Contentful web app > Content:
- Open the product called 'Playsam Streamliner Classic Car, Espresso'.
- Change the value of the Product name field to a new value,
- Click the Publish changes button
- Wait a few seconds for the changes to propagate to the CDN.
- Reload your Express js application and you will see the new product name.
You can continue to edit your content inside the [Contentful web app][13] and see the content change inside your application.
To view the demo application live in your own production environment, follow these steps:
- Having Heroku CLI Installed, Login to Heroku if you're not logged in already:
heroku login
- Create a new instance:
heroku create
- Commit your change:
git add .
git commit -m "Add Website"
- Deploy to Heroku:
git push heroku master
- Open the application in your browser:
heroku open
After this guide, you should be able to start using Contentful with your Express js applications, but every project has different needs and we want to provide you with the best solutions we can.
You can read about the Contentful CDA library in more detail on our contentful.js GitHub or our Getting Started with CDA SDK tutorial. We also suggest taking a look at our Product Example Application.
Do you like building static sites? Check how to build static sites using Contentful with Metalsmith