问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

用html做一个购物车,能实现简单的产品数量和价格的加减就行。最后能...

发布网友 发布时间:2022-04-26 16:53

我来回答

3个回答

热心网友 时间:2022-04-19 06:50

html中的购物车的增减不能直接传送到后台,可以通过ajax,在js中发送ajax

纯前端的话可以参考下面的

<!DOCTYPE html>    
<html lang="en">    
<head>    
<meta charset="UTF-8">    
<title>cart</title>    
<style type="text/css">
    body,p,a,input{
    margin: 0;
    padding: 0;
    font-size: 12px;
}

.container{
    width: 100%;
}

.main{
    width: 1000px;
    height: 500px;

    margin:100px auto;
}

.main .cart-container table{
    width: 100%;



}

.main .cart-container table tr{
    text-align: center;

}

.main .cart-container table tr:hover{
    background: rgba(128, 128, 128, 0.2);
}
.main .cart-container table .table-header{
    height: 30px;
    background: #d9d9d9;

    font-size: 1.2em;

}

.main .cart-container table .table-header td:first-child{
    border-left: solid 4px red;
    box-sizing: border-box;
}

.main .cart-container table tr td:nth-child(1),
.main .cart-container table tr td:nth-child(2){
    text-align: left;

}

.main .cart-container table tr td:nth-child(2){
    width: 52%;
}
.main .cart-container table tr td:nth-child(3){
    width: 12%;
}
.main .cart-container table tr td:nth-child(4){
    width: 12%;
}
.main .cart-container table tr td:nth-child(5){
    width: 12%;
}
.main .cart-container table tr td:last-child{
    width: 10%;
}

.cart-good{

    height: 60px;
}
.cart-good img{
    float: left;
    margin: 10px;
    width: 60px;
}

.cart-good td p{
    margin: 10px 0px;
}


/*加、减按钮*/

.cart-good td input[type='button']{
     width: 20px;
     height: 20px;
     background: #00f300;
     outline: none;
     border: none;
 }

.cart-good td input[type='button']:disabled{
    background: grey;
}

.cart-good td input[type='button']:first-child{
   margin-right: -4px;
}
.cart-good td input[type='button']:last-child{
    margin-left: -4px;
}
.cart-good td input[type='text']{
    width: 30px;
    height: 20px;
    outline: none;
    border: none;
    text-align: center;


}


.table-footer{
    display: flex;
    justify-content: space-between;
    line-height: 40px;
}


.table-footer div{
    font-size: 1.2em;

}
.table-footer div button{
    background: red;
    width: 120px;
    height: 40px;
    color: white;
}
</style>  
</head>    
<body>    
<div class="container">    
<header></header>    
<section class="main">    
<div class="cart-container">    
<table cellspacing="0">    
<tr class="table-header">    
<td><input type="checkbox" id="chk_alla"></td>    
<td>聚美优品发货</td>    
<td>聚美价</td>    
<td>数量</td>    
<td>小计</td>    
<td>操作</td>    
</tr>    
<!--<tr class="cart-good">-->    
<!--<td><input type="checkbox" id="001"></td>-->    
<!--<td>-->    
<!--<img src="https://p2.jmstatic.com/proct/001/293/1293263_std/1293263_60_60.jpg" alt="">-->    
<!--<p>[极速免税]PITTA MASK 口罩3枚入</p>-->    
<!--<p>型号:新版防晒款  容量:3枚入</p>-->    
<!--</td>-->    
<!--<td>89.00</td>-->    
<!--<td>-->    
<!--<input type="button" value="-">-->    
<!--<input type="text" value="1">-->    
<!--<input type="button" value="+">-->    
<!--</td>-->    
<!--<td>89.00</td>-->    
<!--<td><a href="#">删除</a></td>-->    
<!--</tr>-->    
</table>    
<div class="table-footer">    
<div>    
<input type="checkbox" id="chk_allb"> <label for="chk_allb">全选</label>    
<span style="margin-left: 20px">继续购物 | 清空选中商品</span>    
</div>    
<div>    
共 <span id="good_count">5</span>件商品    商品应付总额:<span id="goods_total">¥229.00</span>    
<button class="btn_menu">去结算</button>    
</div>    
</div>    
</div>    
</section>    
</div>    
<script>
(function () {
    var skin_procts= [
        {
            "id":"002",
            "title": "Estee Lauder 多效智妍精华霜15ml",
            "img_url": "http://p0.jmstatic.com/proct/003/565/3565880_std/3565880_350_350.jpg",
            "price": 249.0,
            "number":6,
            "acount": "520",
            "ischecked":true
        },
        {
            "id":"004",
            "title": "EsteeLauder 肌透修护洁面乳30ml",
            "img_url": "http://p4.jmstatic.com/proct/003/155/3155764_std/3155764_350_350.jpg",
            "price": 49.9,
            "number":1,
            "acount": "5911",
            "ischecked":false
        },
        {
            "id":"008",
            "title": "雅诗兰黛无痕持妆粉底液",
            "img_url": "http://p3.jmstatic.com/proct/003/662/3662318_std/3662318_350_350.jpg",
            "price": 69.9,
            "number":2,
            "acount": "3972",
            "ischecked":true
        },
        {
            "id":"0012",
            "title": "Estee Lauder 肌初赋活原生液30ml",
            "img_url": "http://p4.jmstatic.com/proct/003/565/3565914_std/3565914_350_350.jpg",
            "price": 159.0,
            "number":1,
            "acount": "2338"
        },
        {
            "id":"001",
            "title": "雅诗兰黛无痕持妆粉底液30ml",
            "img_url": "http://p2.jmstatic.com/proct/001/648/1648502_std/1648502_350_350.jpg",
            "price": 298.0,
            "number":4,
            "acount": "5071",
            "ischecked":false
        },
        {
            "id":"009",
            "title": "雅诗兰黛眼部精华霜15ml",
            "img_url": "http://p1.jmstatic.com/proct/001/049/1049746_std/1049746_350_350.jpg",
            "price": 399.0,
            "number":1,
            "acount": "4022",
            "ischecked":false
        }
    ]

//    添加商品

    function load() {
        var tbody=document.querySelector('.cart-container table tbody');
        for(let good of skin_procts){
            tbody.innerHTML+=` <tr class="cart-good" id="${good.id}">
                            <td><input type="checkbox" class="good-check" ${good.ischecked?"checked":''}></td>
                            <td>

                                <img src="${good.img_url}" alt="">
                                <p>[极速免税]PITTA MASK 口罩3枚入</p>
                                <p>型号:新版防晒款  容量:3枚入</p>

                            </td>
                            <td>${good.price}</td>
                            <td>

                                <input type="button" value="-"  ${good.number<=1?"disabled":''}>
                                <input type="text" value="${good.number}">
                                <input type="button" value="+">
                            </td>
                            <td>${good.price*good.number}</td>
                            <td><a href="#">删除</a></td>
                        </tr>`
        }

        totalAcount();
    }
    load();
//    end all..........

    // 1. 为table注册单击事件

    var table01=document.querySelector('.cart-container table');

    table01.onclick=function (event) {

        var node=event.target
        if(node.getAttribute('type')=='button'){
            // alert(event.target.value);
            changeNumber(event);
            subtotal(event);
            checkedRow(event);
            checkedAllRows();

        }else if(node.className=='good-check'){
            checkedAllRows();

        }else if(node.id=='chk_alla'){
            var f=event.target.checked;
            var chks=document.querySelectorAll('.good-check');
            for(var ck of chks){
                ck.checked=f;
            }

            for(var good of skin_procts){
                good.ischecked=f;
            }


        }else if(node.nodeName.toLowerCase()=='a'){
            var tr=event.target.parentNode.parentNode;
            for(var i=0;i<skin_procts.length;i++){
                if(skin_procts[i].id==tr.id){
                    skin_procts.splice(i,1);
                    console.log(skin_procts);
                }
            }

            tr.parentNode.removeChild(tr);

        }
        totalAcount();
    };

    //单击增加或减少按钮的方法
    function changeNumber(event) {

        var node=event && event.target;
        var v=0;
        if(node.value && node.value=='+'){
            // node.previousElementSibling.value=parseInt(node.previousElementSibling.value)+1;
            node.previousElementSibling.value++;
            v=node.previousElementSibling.value;
            node.previousElementSibling.previousElementSibling.disabled=false;

        }else{
            // if(node.value && node.value=='+')
            if(node.nextElementSibling.value>1){
                node.nextElementSibling.value--;
                v=node.nextElementSibling.value;
                if(v==1){
                    node.disabled=true;
                }
            }
        }


    //    存储商品数量

        var id=node.parentNode.parentNode.id;

        for(var good of skin_procts){
            if(id==good.id){
                good.number=v;
            }
        }

    }
    
//    每个商品小计的方法
    
    function subtotal(event) {
        var node=event && event.target;

        // var id=node.parentNode.parentNode.id;

        // for(var g of skin_procts){
        //     if(g.id==id){
        //         alert(g.price);
        //     }
        // }


        // var price=;

        var price=node.parentNode.previousElementSibling.innerText;
        var num=node.parentNode.children[1].value;
        node.parentNode.nextElementSibling.innerText=(num*price).toFixed(2);
    }

//    检验该商品是否选中
    function checkedRow(event) {
        event.target.parentNode.parentNode.firstElementChild.firstElementChild.checked=true;
        // event.target.parentNode.parentNode.cells[0].firstElementChild.checked=true;
        // var tbody=event.target.parentNode.parentNode.parentNode;
        // event.target.parentNode.parentNode.parentNode.rows[3].cells[0].firstElementChild.checked=true;
    }
//   检查是否全选

    function checkedAllRows() {
        var chks=document.querySelectorAll('.good-check');
        var flag=true;
        for(var ck of chks){
            if(!ck.checked){
                flag=false;
                break;
            }
        }
        document.querySelector('#chk_alla').checked=flag;

    }


//    统计商品总量和总价格

    function totalAcount() {

        var total=0;
        var total_price=0;
        var chks=document.querySelectorAll('.good-check');
        for(var ck of chks){
            if(ck.checked){
                id=ck.parentNode.parentNode.id;
                for(var good of skin_procts){
                    if(id==good.id){
                        total+=~~good.number;
                        total_price=total_price+(good.number*good.price);
                        good.ischecked=true;


                    }
                }


            }
        }

        document.querySelector('#good_count').innerText=total;
        document.querySelector('#goods_total').innerText=total_price;


    }





})();
</script>    
</body>    
</html>

热心网友 时间:2022-04-19 08:08

用js去实现

热心网友 时间:2022-04-19 09:42

HTML只是前端计算给用户看看的,你可不能直接就把计算总和插进数据库里。服务器上还要重新算一边的追问要是不用链接数据库呢?就只是能计算一下总和呢?

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
怎么把苹果电脑安装到固态硬盘苹果笔记本可以换成固态硬盘吗_百度知 ... 营转非的车保险和私车一样吗? 功夫不负有心人的观点怎么写 用具体事实说明一个观点比如“功夫不负有心人”“虚心使人进步骄傲使... 我左腿膝盖向上10cm外侧刚发现有个硬的包很疼,表面无异样请问是什么`昨 ... 左腿膝盖外侧酸是怎么回事,右腿没感觉,是缺少什么了吗,以前一般吃几天... 膝盖处外侧皮肤麻木,皮肤容易红,外侧摸关节处略大于右腿同部位关节。去... 灰色冬裙配什么短外套 2024年信用卡诈骗罪是什么样的量刑标准 徐州启星中学好不好在徐州排第几徐州启星中学 静态HTML网页可以实现购物车功能吗?而且不用数据库... html中怎么样可以保留点击添加购物车后的查询页面不变 如何用html css javascript php制作购物车? 求html购物车代码,,效果如图显示 我这盆茶花该怎么养? 养茶花的方法 铁观音茶树在北方如何种植! 北方要怎么养好山茶花? 怎样才能使用换热器里的热水 春节腊月二十八习俗有哪些:发面蒸馒头 贴春联窗花 用热水热饭可以吗 关于节日场面的作文 切记使用热水什么意思? 什么节日吃面条,这个节日在几月几日,这个节日特殊的原因,在这一天人们感谢任 30万贷款利率3.5,5年利息多少? 山西民间面塑的春节面塑 春节习俗面面观 描写节日的场面 描写节日热闹场面的作文怎么写 我贷了30万,利息是3%,贷了5年,那这个利息怎么算? javascript+jsp实现在1.html把商品放购物车,在2.html显示购物车内的信息... 在HTML里用javascript做一个简单购物车部分 在HTML里怎么把btn设置成超链接,如图,讲立即购买的按钮链接跳转到购物车页面?? 小学生关于爱护铁路的演讲稿,800到1000字, 求商城购物车具体代码,HTML5+CSS+php的,有没有大神具体给一下或者思路... 求三篇小学生关于爱护铁路,保护铁路的演讲稿。1000字左右,重赏! 一个作业。html做一个购物网站,做几个模板就可以,查看商品,商品展... 求一个HTML商务型网站模板,购物类型的,拥有购物车功能的 小学生铁路安全知识!不要太长! 手机端点击弹窗处的“加入购物车”后,”购物车“处的数字变化怎么在html写 怎么给小学生演讲关于交通安全知识?急求此方面的演讲稿 如何用html编写购物车不连接数据库 有关小学生交通安全教育演讲稿 求一个JS代码,就APP购物车的代码,可以在html直接实现的 关于铁路安全的演讲稿 设计一个购物车,包含html和php两个文件,html让客户输入个人信息以及显 ... 爱护铁路的资料100字(或150字) .net在html中实现购物车的功能如何实现根据不同数量的购物品种,生成多 ... 关于铁路“关爱生命、关注安全”演讲文章 想做一个简单的购物车界面,非常简单就行?有代码!用div+css做就可以...