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
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
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
then open your index.html file in chrome ,you should get this result