" Bootstrap 5 ecommerce product list with animation add to cart button"
Bootstrap 4.1.1 Snippet by Umerfarooq

<link href="//maxcdn.bootstrapcdn.com/bootstrap/4.1.1/css/bootstrap.min.css" rel="stylesheet" id="bootstrap-css"> <script src="//maxcdn.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js"></script> <script src="//cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script> <!------ Include the above in your HEAD tag ----------> <div class="wrapper"> <div class="container"> <div class="row g-1"> <div class="col-md-3"> <div class="card p-3"> <div class="text-center"> <img src="https://i.imgur.com/w2rCsEw.jpg" width="200"> </div> <div class="product-details"> <span class="font-weight-bold d-block">$ 7.00</span> <span>Red Redish</span> <div class="buttons d-flex flex-row"> <div class="cart"><i class="fa fa-shopping-cart"></i></div> <button class="btn btn-success cart-button btn-block"><span class="dot">1</span>Add to cart </button> </div> <div class="weight"> <small>1 piece 2.5kg</small> </div> </div> </div> </div> <div class="col-md-3"> <div class="card p-3"> <div class="text-center"> <img src="https://i.imgur.com/ZRUetRF.jpg" width="200"> </div> <div class="product-details"> <span class="font-weight-bold d-block">$ 7.00</span> <span>Red Redish</span> <div class="buttons d-flex flex-row"> <div class="cart"><i class="fa fa-shopping-cart"></i></div> <button class="btn btn-success cart-button btn-block"><span class="dot">1</span>Add to cart </button> </div> <div class="weight"> <small>1 piece 2.5kg</small> </div> </div> </div> </div> <div class="col-md-3"> <div class="card p-3"> <div class="text-center"> <img src="https://i.imgur.com/0M7pldG.jpg" width="200"> </div> <div class="product-details"> <span class="font-weight-bold d-block">$ 7.00</span> <span>Red Redish</span> <div class="buttons d-flex flex-row"> <div class="cart"><i class="fa fa-shopping-cart"></i></div> <button class="btn btn-success cart-button btn-block"><span class="dot">1</span>Add to cart </button> </div> <div class="weight"> <small>1 piece 2.5kg</small> </div> </div> </div> </div> <div class="col-md-3"> <div class="card p-3"> <div class="text-center"> <img src="https://i.imgur.com/emb60L5.jpg" width="200"> </div> <div class="product-details"> <span class="font-weight-bold d-block">$ 7.00</span> <span>Red Redish</span> <div class="buttons d-flex flex-row"> <div class="cart"><i class="fa fa-shopping-cart"></i></div> <button class="btn btn-success cart-button btn-block"><span class="dot">1</span>Add to cart </button> </div> <div class="weight"> <small>20 piece 2.5kg</small> </div> </div> </div> </div> </div> </div> </div>
body { background: #eee } .wrapper { margin-top: 30px } .card { border: 1px solid #eee; cursor: pointer } .weight { margin-top: -65px; transition: all 0.5s } .weight small { color: #e2dede } .buttons { padding: 10px; background-color: #d6d4d44f; border-radius: 4px; position: relative; margin-top: 7px; opacity: 0; transition: all 0.8s } .dot { height: 14px; width: 14px; background-color: green; border-radius: 50%; position: absolute; left: 27%; display: flex; justify-content: center; align-items: center; font-size: 8px; color: #fff; opacity: 0 } .cart-button { height: 48px } .cart-button:focus { box-shadow: none } .cart { position: relative; height: 48px !important; width: 50px; margin-right: 8px; display: flex; justify-content: center; align-items: center; background-color: #fff; padding: 11px; border-radius: 5px; font-size: 14px; transition: 1s ease-in-out; overflow: hidden } .cart-button.clicked span.dot { animation: item 0.3s ease-in forwards } @keyframes item { 0% { opacity: 1; top: 30%; left: 30% } 25% { opacity: 1; left: 26%; top: 0% } 50% { opacity: 1; left: 23%; top: -22% } 75% { opacity: 1; left: 19%; top: -18% } 100% { opacity: 1; left: 14%; top: 28% } } .card:hover .buttons { opacity: 1 } .card:hover .weight { margin-top: 10px } .card:hover { transform: scale(1.04); z-index: 2; overflow: hidden }
document.addEventListener("DOMContentLoaded", function(event) { const cartButtons = document.querySelectorAll('.cart-button'); cartButtons.forEach(button => { button.addEventListener('click',cartClick); }); function cartClick(){ let button =this; button.classList.add('clicked'); } });

Related: See More


Questions / Comments:

I like it, but what if the product description is longer? Like say the second one is for argument's sake, Corn on the Cob, 2 dozen and a half. That makes the card longer and the others don't stretch to match.

Mel250 () - 2 months ago - Reply 0


I like it, but what if the product description is longer? Like say the second one is for argument's sake, Corn on the Cob, 2 dozen and a half. That makes the card longer and the others don't stretch to match.

Mel250 () - 2 months ago - Reply 0


I like it, but what if the product description is longer? Like say the second one is for argument's sake, Corn on the Cob, 2 dozen and a half. That makes the card longer and the others don't stretch to match.

Mel250 () - 2 months ago - Reply 0