首页 > web前端 > js教程 > 正文

JavaScript怎么实现购物车结算

藏色散人
发布: 2021-07-03 10:12:57
原创
3657人浏览过
JavaScript实现购物车结算的方法:1、在页面加载后执行function;2、获取元素;3、设置加减按钮;4、另存下标;5、设置加减号的点击事件;6、创建复选框的状态改变事件。

JavaScript怎么实现购物车结算

本文操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

JavaScript怎么实现购物车结算?

1.gif

HTML代码:

立即学习Java免费学习笔记(深入)”;

<div id="container">
    <ul>
        <li>
            <input type="checkbox" name="liCheck" id="" value="">
            <button type="button" class="decrease" disabled="disabled">-</button>
            <p>
                <span class="piece">0</span>件
            </p>
            <button type="button" class="increase">+</button>
            <p>
                <span class="price">10</span>元
            </p>
            <p>
                小计:
                <input class="smallPrice" type="text" name="" id="" value="0" disabled="disabled">
            </p>
        </li>
        <li>
            <input type="checkbox" name="liCheck" id="" value="">
            <button type="button" class="decrease" disabled="disabled">-</button>
            <p>
                <span class="piece">0</span>件
            </p>
            <button type="button" class="increase">+</button>
            <p>
                <span class="price">20</span>元
            </p>
            <p>
                小计:
                <input class="smallPrice" type="text" name="" id="" value="0" disabled="disabled">
            </p>
        </li>
        <li>
            <input type="checkbox" name="liCheck" id="" value="">
            <button type="button" class="decrease" disabled="disabled">-</button>
            <p>
                <span class="piece">0</span>件
            </p>
            <button type="button" class="increase">+</button>
            <p>
                <span class="price">30</span>元
            </p>
            <p>
                小计:
                <input class="smallPrice" type="text" name="" id="" value="0" disabled="disabled">
            </p>
        </li>
        <li>
            <input type="checkbox" name="liCheck" id="" value="">
            <button type="button" class="decrease" disabled="disabled">-</button>
            <p>
                <span class="piece">0</span>件
            </p>
            <button type="button" class="increase">+</button>
            <p>
                <span class="price">40</span>元
            </p>
            <p>
                小计:
                <input class="smallPrice" type="text" name="" id="" value="0" disabled="disabled">
            </p>
        </li>
        <li>
            <input type="checkbox" name="liCheck" id="" value="">
            <button type="button" class="decrease" disabled="disabled">-</button>
            <p>
                <span class="piece">0</span>件
            </p>
            <button type="button" class="increase">+</button>
            <p>
                <span class="price">50</span>元
            </p>
            <p>
                小计:
                <input class="smallPrice" type="text" name="" id="" value="0" disabled="disabled">
            </p>
        </li>
    </ul>
    <div class="sum">
        <label>
<input type="checkbox" name="" id="checkAll" value="">全选
</label>
        <p>
            商品总计:
            <span id="totalCount">0</span>
        </p>
        <p>
            商品总价:
            <span id="totalPrice">0</span>
        </p>
    </div>
</div>
CSS代码:
html,body,ul,p {
margin:0;
padding:0;
}
ul,li {
list-style:none;
}
ul {
width:450px;
}
li {
display:flex;
justify-content:space-around;
}
.sum {
width:450px;
display:flex;
justify-content:space-around;
}
#container {
width:450px;
margin:100px auto;
}
登录后复制

JS代码:

// 1.页面加载后执行
window.onload = function() {
    // 2.获取元素
    var liCheck = document.getElementsByName("liCheck"); //li里面的复选框
    var decrease = document.getElementsByClassName("decrease"); //减号
    var piece = document.getElementsByClassName("piece"); //件数
    var increase = document.getElementsByClassName("increase"); //加号
    var price = document.getElementsByClassName("price"); //单价
    var smallPrice = document.getElementsByClassName("smallPrice"); //小计
    var checkAll = document.getElementById("checkAll"); //全选复选框
    var totalCount = document.getElementById("totalCount"); //总计
    var totalPrice = document.getElementById("totalPrice"); //总价
    // 3.加减按钮
    for (var i = 0; i < decrease.length; i++) {
        // 4.另存下标
        decrease[i].index = i;
        increase[i].index = i;
        liCheck[i].index = i;
        // 5.减号的点击事件
        decrease[i].onclick = function() {
            // 5-1.判断件数是否大于0
            if (piece[this.index].innerHTML <= 1) {
                this.disabled = true; //当件数小于等于0时, 将减号按钮禁用
            }
            // 5-1-1.当前件数-1
            piece[this.index].innerHTML--;
            // 5-1-2.计算小计
            smallPrice[this.index].value = Number(smallPrice[this.index].value) - Number(price[this.index].innerHTML);
            // 6-4.如果当前条目是被选中状态, 则需要将该商品计入总计和总价
            if (liCheck[this.index].checked) { //选中
                totalCount.innerHTML--;
                totalPrice.innerHTML = Number(totalPrice.innerHTML) - Number(price[this.index].innerHTML);
            }
        }
        // 6.加号的点击事件
        increase[i].onclick = function() {
            // 6-1.将对应的减号解禁
            decrease[this.index].disabled = false;
            // 6-2.当前件数+1
            piece[this.index].innerHTML++;
            // 6-3.计算小计
            smallPrice[this.index].value = Number(smallPrice[this.index].value) + Number(price[this.index].innerHTML);
            // 6-4.如果当前条目是被选中状态, 则需要将该商品计入总计和总价
            if (liCheck[this.index].checked) { //选中
                totalCount.innerHTML++;
                totalPrice.innerHTML = Number(totalPrice.innerHTML) + Number(price[this.index].innerHTML);
            }
        }
        // 7.复选框的状态改变事件
        var count = 0; //存储选中个数
        liCheck[i].onchange = function() {
            // 7-1.判断是否选中
            if (this.checked) { //选中状态
                count++;
                totalCount.innerHTML = Number(totalCount.innerHTML) + Number(piece[this.index].innerHTML); //总计加当前件数
                totalPrice.innerHTML = Number(totalPrice.innerHTML) + Number(smallPrice[this.index].value); //总计加当前件数
                // 7-1-1. 判断选中个数是否与复选框个数一致
            } else { //取消选中状态
                count--;
                totalCount.innerHTML = Number(totalCount.innerHTML) - Number(piece[this.index].innerHTML); //总计加当前件数
                totalPrice.innerHTML = Number(totalPrice.innerHTML) - Number(smallPrice[this.index].value); //总计加当前件数
            }
            count == liCheck.length ? checkAll.checked = true : checkAll.checked = false;
        }
    }
    // 8.全选复选框
    checkAll.onchange = function() {
        totalCount.innerHTML = 0; //总计置为0
        totalPrice.innerHTML = 0; //总价置为0
        for (var j = 0; j < liCheck.length; j++) {
            // 8-1. 将li里面的复选框与全选状态保持一致
            liCheck[j].checked = this.checked;
            // 8-2. 判断是否全选
            if (this.checked) {
                count = liCheck.length;
                totalCount.innerHTML = Number(totalCount.innerHTML) + Number(piece[j].innerHTML);
                totalPrice.innerHTML = Number(totalPrice.innerHTML) + Number(smallPrice[j].value);
            } else {
                count = 0;
            }
        }
    }
}
登录后复制

推荐学习:《javascript高级教程

以上就是JavaScript怎么实现购物车结算的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号