实现效果:

javascript购物车代码 前端实现购物车js代码_html

CSS样式: 

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        table {
            width: 50%;
            margin: 1.5rem auto;
            border-collapse: collapse;
            border: .1rem solid gray;
        }

        th {
            background: yellow;
            height: 1rem;
            border: .1rem solid gray;
        }

        tr {
            height: 1rem;
            text-align: center;
        }

        td {
            border: .1rem solid gray;
        }
    </style>
</head>

 HTML代码:

<body>
    <table>
        <tr>
            <th>商品名称</th>
            <th>数量</th>
            <th>单价</th>
            <th>小计</th>
            <th>操作</th>
        </tr>
        <tr>
            <td>西瓜</td>
            <td>
                <button>-</button>
                <span class="goods-num">0</span>
                <button>+</button>
            </td>
            <td>
                单价:<span>5</span>
            </td>
            <td>
                小计:<span class="goods-subtotal">0</span>
            </td>
            <td>
                操作:<input type="button" value="删除">
            </td>
        </tr>
        <tr>
            <td>樱桃</td>
            <td>
                <button>-</button>
                <span class="goods-num">0</span>
                <button>+</button>
            </td>
            <td>
                单价:<span>10</span>
            </td>
            <td>
                小计:<span class="goods-subtotal">0</span>
            </td>
            <td>
                操作:<input type="button" value="删除">
            </td>
        </tr>
        <tr>
            <td colspan="5">一共<span class="goods-total-num">0</span>件商品,一共<span class="goods-total-price">0</span>元</td>
        </tr>
    </table>
</body>

JS代码:

<script>
    class Cart {
        //更新总数
        updateGoodsTotalNum() {
            //获取到数量中间的数字==数组中保存
            let oGoodsNum = document.getElementsByClassName("goods-num")
            //设置总数量的初始数字为0
            let goodsTotalNum = 0;
            //总的数量是将所有的商品数量加起来
            for (let i = 0; i < oGoodsNum.length; i++) {
                goodsTotalNum += oGoodsNum[i].innerHTML / 1;
            }
            //获取到总数的这个span标签,注意是class名,要打点
            let oGoodsTotalNum = document.querySelector(".goods-total-num");
            //总数的值=累加起来的goodsTotalNum
            oGoodsTotalNum.innerHTML = goodsTotalNum;
        }
        //更新商品总价格
        updateGoodsTotalPrice() {
            //获取到小结中间的数字
            let oGoodsSubtotal = document.getElementsByClassName("goods-subtotal");
            //给总价钱设置初始值为0
            let goodsTotalprice = 0;
            //总的钱数是将所有的商品钱数加起来
            for (let i = 0; i < oGoodsSubtotal.length; i++) {
                goodsTotalprice += oGoodsSubtotal[i].innerHTML / 1;
            }
            //获取到总钱数的这个span标签,注意是class名,要打点
            let oGoodsTotalprice = document.querySelector(".goods-total-price");
            //总钱数的值=累加起来的goodsTotalprice
            oGoodsTotalprice.innerHTML = goodsTotalprice;
        }
        //添加货物
        //btn就是被点击的元素
        addGoods(btn) {
            //1数量
            //找到在+号按钮的上一个兄弟节点
            let oGoodsNum = btn.previousElementSibling;
            //商品的数量=原来商品的数量+1;
            oGoodsNum.innerHTML = oGoodsNum.innerHTML / 1 + 1;
            //2小计=数量*单价
            //找到+号按钮的父节点的下一个节点的第一个孩子,就是相当于是找到了单价这个需要改的数字
            let oGoodsPrice = btn.parentNode.nextElementSibling.firstElementChild;
            //就是相当于是找到了小计这个需要改的数字
            let oGoodsSubtotal = btn.parentNode.nextElementSibling.nextElementSibling.firstElementChild;
            oGoodsSubtotal.innerHTML = oGoodsNum.innerHTML * oGoodsPrice.innerHTML;
            //3总个数
            this.updateGoodsTotalNum();
            //4总价
            this.updateGoodsTotalPrice();
        }

        minGoods(btn) {
            let oGoodsNum = btn.nextElementSibling;
            //如果商品的数量大于0
            if (oGoodsNum.innerHTML > 0) {
                //商品的数量在原数量的基础上减一
                oGoodsNum.innerHTML = oGoodsNum.innerHTML / 1 - 1;
                //找到单价的
                let oGoodsPrice = btn.parentNode.nextElementSibling.firstElementChild;
                //找到小结的
                let oGoodsSubtotal = btn.parentNode.nextElementSibling.nextElementSibling.firstElementChild;
                //小结=数目*单价
                oGoodsSubtotal.innerHTML = oGoodsNum.innerHTML * oGoodsPrice.innerHTML;
                // 3.总数
                this.updateGoodsTotalNum();
                // 4.总价
                this.updateGoodsTotalPrice();
            }
        }

        //删除按钮
        delGoods(btn) {
            //找到删除按钮的父的父,就相当于是要被删除的这一行
            let oTr = btn.parentNode.parentNode;
            //将这一行删除
            oTr.remove();
            //调用计算总数和总价的,重新计算
            this.updateGoodsTotalNum();
            this.updateGoodsTotalPrice();
        }


        evenBind() {
            //找到 -和+的按钮
            let oBtns = document.getElementsByTagName("button");
            //遍历找到所点击的
            let that = this;
            for (let i = 0; i < oBtns.length; i++) {
                //如果索引是偶数的话,是-
                if (i % 2 == 0) {
                    oBtns[i].onclick = function () {
                        that.minGoods(this)
                    }
                } else {
                    //如果索引是奇数的话,是+
                    oBtns[i].onclick = function () {
                        that.addGoods(this)
                    }
                }
            }

            
            //找到删除的按钮
            let delBtns = document.getElementsByTagName("input");
            //遍历,看点击的是哪一个删除
            for (let i = 0; i < delBtns.length; i++) {
                delBtns[i].onclick = function () {
                    that.delGoods(this);
                }
            }
        }
    }
    let c = new Cart();
    c.evenBind();

</script>