Edit the code so that there is a total price on the checkout.html page of the items in your cart. Add a form below that takes name , email, phone number, and credit card number. Use a regular expression to validate the email, phone number, and credit card. Existing code: products.html Cart shoppingcart.js const product = [ { id: 1, name: "Clorox", price: "$20.00", image: "img/clorox.jpg", category: "Household Cleaner", }, { id: 2, name: "Oxiclean", price: "$8.00", // image: "img/oxiclean.jpg", image: "https://images-na.ssl-images-amazon.com/images/I/811eCrdKg-L._SY450_.jpg", category: "Household Cleaner", }, { id: 3, name: "PineSol", price: "$11.00", // image: "img/pinesol.jpg", image: "https://www.pinesol.com/wp-content/themes/electro/img/products/bottle-original-pine-large.png", category: "Household Cleaner", }, { id: 4, name: "Mr Clean", price: "$12.00", // image: "img/mrclean.jpg", image: "https://upload.wikimedia.org/wikipedia/en/7/73/Mr._Clean_logo.png", category: "Household Cleaner", }, { id: 5, name: "Windex", price: "$15.00", // image: "img/windex.jpg", image: "https://images-na.ssl-images-amazon.com/images/I/71tgjDr5mtL._AC_SX466_.jpg", category: "Household Cleaner", }, ]; product.forEach((element, index) => { let products = ""; products += ""; products += ""; products += "" + element.name + ""; products += "" + element.price + ""; products += "" + element.category + ""; products += "Add to cart"; products += "Remove From Cart"; document.getElementById("productsDiv").innerHTML += products; }); var cart = new Array(); localStorage.removeItem("myItems"); updateCart(); function updateCart(){ let items = localStorage.getItem("myItems") ? JSON.parse(localStorage.getItem("myItems")) : []; var cartCount = document.getElementById("cartCount"); cartCount.innerHTML="("+items.length+") "; } function addtocart(productid) { let object1 = product.filter(item=>item.id==productid)[0]; let alreadyItems = localStorage.getItem("myItems") ? JSON.parse(localStorage.getItem("myItems")) : []; alreadyItems.push(object1); localStorage.setItem("myItems", JSON.stringify(alreadyItems)); updateCart(); console.log(alreadyItems) } function removecart(productid) { const index = cart.indexOf(productid); if (index > -1) { cart.splice(index, 1); } updateCart(); console.log(cart); } checkout.html Document
Edit the code so that there is a total price on the checkout.html page of the items in your cart. Add a form below that takes name , email, phone number, and credit card number. Use a regular expression to validate the email, phone number, and credit card.
Existing code:
products.html
<!DOCTYPE html>
<html>
<head>
<style>
img {
width: 80px;
height: auto;
}
</style>
</head>
<body>
<div style="width: 100%;text-align: right;">
<a href="checkout.html">
<h3><span id="cartCount"></span>Cart</h3>
</a>
</div>
<div id="productsDiv"></div>
<script src="./js/shoppingcart.js"></script>
</body>
</html>
shoppingcart.js
const product = [
{
id: 1,
name: "Clorox",
price: "$20.00",
image: "img/clorox.jpg",
category: "Household Cleaner",
},
{
id: 2,
name: "Oxiclean",
price: "$8.00",
// image: "img/oxiclean.jpg",
image:
"https://images-na.ssl-images-amazon.com/images/I/811eCrdKg-L._SY450_.jpg",
category: "Household Cleaner",
},
{
id: 3,
name: "PineSol",
price: "$11.00",
// image: "img/pinesol.jpg",
image:
"https://www.pinesol.com/wp-content/themes/electro/img/products/bottle-original-pine-large.png",
category: "Household Cleaner",
},
{
id: 4,
name: "Mr Clean",
price: "$12.00",
// image: "img/mrclean.jpg",
image: "https://upload.wikimedia.org/wikipedia/en/7/73/Mr._Clean_logo.png",
category: "Household Cleaner",
},
{
id: 5,
name: "Windex",
price: "$15.00",
// image: "img/windex.jpg",
image:
"https://images-na.ssl-images-amazon.com/images/I/71tgjDr5mtL._AC_SX466_.jpg",
category: "Household Cleaner",
},
];
product.forEach((element, index) => {
let products = "";
products += "<div id='product" + element.id + "' class='card'>";
products += "<img src='" + element.image + "' />";
products += "<h1>" + element.name + "</h1>";
products += "<p class='price'>" + element.price + "</p>";
products += "<p>" + element.category + "</h1>";
products +=
"<p><button id='product" +
element.id +
"Btn" +
element.id +
"' onclick='addtocart(" +
element.id +
")'>Add to cart</button></p>";
products +=
"<p><button id='product" +
element.id +
"Btn" +
(element.id + 1) +
"' onclick='removecart(" +
element.id +
")'>Remove From Cart</button></p>";
document.getElementById("productsDiv").innerHTML += products;
});
var cart = new Array();
localStorage.removeItem("myItems");
updateCart();
function updateCart(){
let items = localStorage.getItem("myItems") ? JSON.parse(localStorage.getItem("myItems")) : [];
var cartCount = document.getElementById("cartCount");
cartCount.innerHTML="("+items.length+") ";
}
function addtocart(productid) {
let object1 = product.filter(item=>item.id==productid)[0];
let alreadyItems = localStorage.getItem("myItems") ? JSON.parse(localStorage.getItem("myItems")) : [];
alreadyItems.push(object1);
localStorage.setItem("myItems", JSON.stringify(alreadyItems));
updateCart();
console.log(alreadyItems)
}
function removecart(productid) {
const index = cart.indexOf(productid);
if (index > -1) {
cart.splice(index, 1);
}
updateCart();
console.log(cart);
}
checkout.html
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
img {
width: 80px;
height: auto;
}
</style>
</head>
<body>
<div id="productsFromCart">
</div>
<script>
let items = localStorage.getItem("myItems") ? JSON.parse(localStorage.getItem("myItems")) : [];
items.forEach((element,index) => {
let products = "";
products += "<div id='product" + element.id + "' class='card'>";
products += "<img src='" + element.image + "' />";
products += "<h1>" + element.name + "</h1>";
products += "<p class='price'>" + element.price + "</p>";
products += "<p>" + element.category + "</h1>";
document.getElementById("productsFromCart").innerHTML += products;
});
</script>
</body>
</html>
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Step by step
Solved in 2 steps
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/741da/741da0cea27bfc4afcecba2c359e4bfe1cd520b7" alt="Computer Networking: A Top-Down Approach (7th Edi…"
data:image/s3,"s3://crabby-images/aa558/aa558fb07235ab55e06fe3a3bc3f597042097447" alt="Computer Organization and Design MIPS Edition, Fi…"
data:image/s3,"s3://crabby-images/c6dd9/c6dd9e6795240236e2b28c31c737e700c2dd7df3" alt="Network+ Guide to Networks (MindTap Course List)"
data:image/s3,"s3://crabby-images/741da/741da0cea27bfc4afcecba2c359e4bfe1cd520b7" alt="Computer Networking: A Top-Down Approach (7th Edi…"
data:image/s3,"s3://crabby-images/aa558/aa558fb07235ab55e06fe3a3bc3f597042097447" alt="Computer Organization and Design MIPS Edition, Fi…"
data:image/s3,"s3://crabby-images/c6dd9/c6dd9e6795240236e2b28c31c737e700c2dd7df3" alt="Network+ Guide to Networks (MindTap Course List)"
data:image/s3,"s3://crabby-images/7daab/7daab2e89d2827b6568a3205a22fcec2da31a567" alt="Concepts of Database Management"
data:image/s3,"s3://crabby-images/cd999/cd999b5a0472541a1bb53dbdb5ada535ed799291" alt="Prelude to Programming"
data:image/s3,"s3://crabby-images/39e23/39e239a275aed535da3161bba64f5416fbed6c8c" alt="Sc Business Data Communications and Networking, T…"