jQuery實現購物車全功能
本文實例為大傢分享瞭jQuery實現購物車全功能的具體代碼,供大傢參考,具體內容如下
效果圖:
HTML&&CSS:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <script src="../jquery-3.4.1.min.js"></script> <style> * { margin: 0; padding: 0; } .tab { width: 500px; border-collapse: collapse; margin: 0 auto; } .tab td, th { border: 1px solid #000; } .tab .num { width: 20px; } .tab .add, .sub { width: 20px; } .current { background-color: pink; } </style> </head> <body> <table class="tab"> <thead> <th>全選 <input type="checkbox" name="" value="" class="checkAll"> <input type="checkbox" name="" value="" class="checkAll"> </th> <th>商品名稱</th> <th>單價</th> <th>數量</th> <th>小計</th> <th>操作</th> </thead> <tbody> <tr> <td><input type="checkbox" class="ed" /></td> <td>電腦</td> <td class="price">¥200.20</td> <td> <button type="button" class="sub">-</button> <input type="text" name="" value="1" class="num"> <button type="button" class="add">+</button> </td> <td class="small_total">¥200.20</td> <td class="delete">刪除</td> </tr> <tr> <td><input type="checkbox" class="ed" /></td> <td>手機</td> <td class="price">¥100.30</td> <td> <button type="button" class="sub">-</button> <input type="text" name="" value="1" class="num"> <button type="button" class="add">+</button> </td> <td class="small_total">¥100.30</td> <td class="delete">刪除</td> </tr> <tr> <td><input type="checkbox" class="ed" /></td> <td>空調</td> <td class="price">¥1000.99</td> <td> <button type="button" class="sub">-</button> <input type="text" name="" value="1" class="num"> <button type="button" class="add">+</button> </td> <td class="small_total">¥1000.99</td> <td class="delete">刪除</td> </tr> </tbody> </table> <div> <span>已選<span style="color: red;" class="num_sum">1</span>件商品</span> <span>總計:</span> <span class="sum" style="color: red;">0</span> <div><span style="color: red;" class="delSome">刪除選中商品</span> <span style="color: red;" class="delAll">清空購物車</span> </div> </div> </body> </html>
JS:
//裡面三個小的復選按鈕選中狀態跟著 全選按鈕走 //因為checked是復選框的固有屬性,此時利用prop()獲取和設置該屬性 $(function() { getSum(); $(".checkAll").change(function() { // console.log($(this).prop("checked"));//全選按鈕的狀態 $(".ed,.checkAll").prop("checked", $(this).prop("checked")); getSum(); if ($(".ed,.checkAll").prop("checked")) { //如果全選,讓所有商品添加類名(背景顏色) $(".tab tbody").children().addClass("current"); } else { $(".tab tbody").children().removeClass("current"); } }) //如果所有小按鈕的個數都被選瞭,全選按鈕就選上,如果小按鈕沒有被選上,則全選按鈕就不選上 //:checked選擇器,查找本選中的表單元素 $(".ed").change(function() { // console.log($(".ed:checked").length);//小復選框選中的個數 // console.log($(".ed").length); //console.log($(this).prop("checked")); if ($(".ed:checked").length === $(".ed").length) { $(".checkAll").prop("checked", true); } else { $(".checkAll").prop("checked", false); } getSum(); if ($(this).prop("checked")) { $(this).parents("tr").addClass("current"); } else { $(this).parents("tr").removeClass("current"); } }) $(".add").click(function() { let n = parseInt($(this).siblings(".num").val()); //console.log(n); n++; $(this).siblings(".num").val(n); let price = $(this).parent().siblings(".price").html(); price = price.substr(1); //console.log(price); $(this).parent().siblings(".small_total").text("¥" + (n * price).toFixed(2)); getSum(); }) $(".sub").click(function() { let n = parseInt($(this).siblings(".num").val()); //console.log(n); if (n === 1) { return false; } n--; $(this).siblings(".num").val(n); let price = $(this).parent().siblings(".price").html(); price = price.substr(1); //console.log(price); $(this).parent().siblings(".small_total").text("¥" + (n * price).toFixed(2)); getSum(); }) //用戶也可以直接修改表單num裡面的值(小bug),同樣計算小計 $(".num").change(function() { let n = $(this).val(); let price = $(this).parent().siblings(".price").html(); price = price.substr(1); $(this).parent().siblings(".small_total").text("¥" + (n * price).toFixed(2)); getSum(); }) function getSum() { let count = 0; //計算總件數 let money = 0; //計算總價錢 $(".num").each(function(index) { if ($(".ed").eq(index).prop("checked") == true) { count += parseInt($(".num").eq(index).val()); money += parseFloat($(".small_total").eq(index).text().substr(1)); } }) $(".num_sum").html(count); $(".sum").html(money.toFixed(2)); } //刪除商品模塊 //點擊刪除之後一定是刪除當前的商品,所以從$(this)出發 $(".delete").click(function() { //刪除的是當前的商品 $(this).parent().remove(); $(".ed").change(); getSum(); clearCheckAll(); }) //刪除選定的商品:小的復選框如果選中就刪除對應的商品 $(".delSome").click(function() { //刪除的是選中的商品 $(".ed:checked").parent().parent().remove(); getSum(); clearCheckAll(); }) //清空購物車 $(".delAll").click(function() { $(".tab tbody").empty(); getSum(); clearCheckAll(); }) function clearCheckAll() { if ($(".tab tbody")[0].innerText == '') { $(".checkAll").prop("checked", false); } } })
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。