Create a simple API with nodejs , and consume it with vanilla javascript

this a step-by-step tutorial to create your first simple api and consume it , this is a very simple tutorial and it doesn’t do anything complex ,it’s for complete beginners

The APP we are going to build together

Capture d’écran 2022-11-19 213659.png

Prerequisites:

  • have basic understanding of html , css and javascript,node

  • visual code studio

First Step: folder structure

  • install nodejs if you don’t have it in your machine already, checkout this link https://nodejs.org/en/

  • create a directory with name of nodeproductsapp

  • create these files index.html , script.js , style.css , server.js

  • create a folder of name data and inside of it, create a new file products.json that will contain our data

[{
    "id":0,
    "productName":"air pods 2022",
    "image":"",
    "productPrice":100

},
{
    "id":1,
    "productName":"gaming pc",
    "image":"",
    "productPrice":1600

},
{
    "id":2,
    "productName":"iphone 13",
    "image":"",
    "productPrice":1000

}]

so then folder structure would be something like this

Capture d’écran 2022-11-16 013400.png

Second step : html file

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <Link href="./style.css" rel="stylesheet"/>
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>tech Products</title>
</head>
<body>

    <main >
        <h1>Tech Products</h1>
        <div id="productsContainer">

    </div>
    </main>

    <script src="script.js"></script>
</body>
</html>

copy paste this code to your html file , we will add the content using javascript .

Third Step : css file

/* general style*/
body {
    background-color: #161c24;
    font-family: Arial, Helvetica, sans-serif;
    color: white;
}
/************************************************/

/* header style */

main h1{
    width: 100%;
    text-align: center;
    margin-bottom: 40px;
}

/*************/

/* Products Container */
#productsContainer{
    display: flex;
    justify-content: center;
    align-items: center;
    gap:20px;
    flex-wrap: wrap;
}

/* Product Card Style*/
.productCard{
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 256px;
    height: 367px;
    background-color: #212b36;
    border-radius: 30px;
}

.imageContainer{
   margin: 10px;
   width: 240px;
   height: 240px;
   border-radius: 15px;
   overflow: hidden;
}

.imageContainer img{
    width:100%;
    height: 100%;
}

.contentContainer{
    width: 90%;
}

.contentContainer h1{
    width: 100%;
   text-align: left;
}

.contentContainer button{
    width:80px;
    height: 40px;
    color: white;
    background-color: #00ab55;
    border: 1px solid  #00ab55;
    border-radius: 10px;
    cursor: pointer;
    font-weight: bold;
}

.price{
  display: flex;
justify-content: space-between;
align-items: center;
}

this is style ,doesn’t need any explanation

fourth step: script.js file

// get main tag
const productsContainer = document.getElementById("productsContainer");

// return product Card Structure html + css classes
const getProductCardStructure = (productName, productPrice, productImage) => {
  const ProductCardSection = document.createElement("section");
  ProductCardSection.classList.add("productCard");

  ProductCardSection.innerHTML = `

            <div class="imageContainer">
               <img src=${productImage} />
            </div>
            <div class="contentContainer">


               <div>
                 <h1>${productName}</h1>

                 </div>
                <div class="price">
                   <button>Buy Now</button>
                   <h2>$${productPrice}</h2>
                </div>
            </div>



  `;

  return ProductCardSection;
};

// add product cards to dom
const addCardProductTodDom = (productsList) => {
  for (let product of productsList) {
    productsContainer.appendChild(
      getProductCardStructure(
        product.productName,
        product.productPrice,
        product.image
      )
    );
  }
};

// get products data from local server
const getProductsData = async () => {
  const data = await fetch("http://127.0.0.1:5000/data");
  const productsList = await data.json();
  return productsList;
};

getProductsData().then((productsList) => addCardProductTodDom(productsList));

Explanation:

so now I will explain script.js file line by line

const productsContainer = document.getElementById("productsContainer");

so first we get products container element (we declare it in our html file) that will wrap all product cards

const getProductCardStructure = (productName, productPrice, productImage) => {
  const ProductCardSection = document.createElement("section");
  ProductCardSection.classList.add("productCard");

  ProductCardSection.innerHTML = `

            <div class="imageContainer">
               <img src=${productImage} />
            </div>
            <div class="contentContainer">


               <div>
                 <h1>${productName}</h1>

                 </div>
                <div class="price">
                   <button>Buy Now</button>
                   <h2>$${productPrice}</h2>
                </div>
            </div>



  `;

  return ProductCardSection;
};

what this function basically do is it get product name ,price and image then we create our productcard using createElement function then we append our html code that contains data of product and css classes to our productCard that we created and return it


// add product cards to dom
const addCardProductTodDom = (productsList) => {
  for (let product of productsList) {
    productsContainer.appendChild(
      getProductCardStructure(
        product.productName,
        product.productPrice,
        product.image
      )
    );
  }
};

all what this function is doing is it takes an array of products objects ,then add it to our products container

// get products data from local server
const getProductsData = async () => {
  const data = await fetch("http://127.0.0.1:5000/data");
  const productsList = await data.json();
  return productsList;
};

the rule of this function is to get products data from our local server

getProductsData().then((productsList) => addCardProductTodDom(productsList));

in this line we call our function that gets our data ,and it’s an async function so we have to wait until it finish executing then after that we take that data and pass it to our “addCardProductTodDom”

that will add it to our DOM


fifth step: server.js file

const http = require("http");
const fs = require("fs");

const ProductsData = fs.readFileSync("./data/products.json");

const server = http.createServer((req, res) => {
  const pathName = req.url;

  // data path
  if (pathName === "/data") {
    // solve cors policy bug and specify type of response data
    res.writeHead(200, {
      "Access-Control-Allow-Origin": "*",
      "Content-type": "application/json",
    });
    res.end(ProductsData);
  }

  // not found path
  else {
    res.end("not found path");
  }
});

// listen to server
server.listen(5000, () => {
  console.log("listening on port 5000");
});

Explanation

const http = require("http");
const fs = require("fs");

in these two lines we import http module that we will use to create our server,,and fs module we will need it read data from our “productsdata.json” file

const ProductsData = fs.readFileSync("./data/products.json");

we read our productsdata using readFileSync method of fs module

const server = http.createServer((req, res) => {
  const pathName = req.url;

  // data path
  if (pathName === "/data") {
    // solve cors policy bug and specify type of response data
    res.writeHead(200, {
      "Access-Control-Allow-Origin": "*",
      "Content-type": "application/json",
    });
    res.end(ProductsData);
  }

  // not found path
  else {
    res.end("not found path");
  }
});

in this block of code we use createServer Method that will fire with every request the server gets

and basically what it does is check if the path name is “/data” if true ,it will return the products data we read earlier using fs module ,if not it will return “not found path”

// listen to server
server.listen(5000, () => {
  console.log("listening on port 5000");
});

in this line we start our server in port 5000

Final Result

now to see the final result ,go to your terminal in vs code and type “node server.js”

you should see something like this

Capture d’écran 2022-11-19 213441.png

then open your index.html file in chrome ,you should get this result

Capture d’écran 2022-11-19 213659.png

Thanks for reading till here ,I really appreciate it

waiting for your feedback