实现购物车物品删除,数量增加减少,选中,批量删除,结算功能,金额汇总,商品数量汇总,前端代码时借用一个博主小哥的,因为本博主对前端显示界面的美化不擅长,这里为了方便,就引用其他博主小哥的前端界面代码!!如果写的不好,望见谅,欢迎大众指出我的不足。

 前端css

* {margin:0;padding:0;
}
body {font-size:13px;
}
input {vertical-align:middle;
}
a {text-decoration:none;color:#333333;
}
.fl {float:left;
}
.fr {float:right;
}
.pro-main {width:1000px;margin:100px auto;
}
.cart-info .all,.cart-info .pro-info,.cart-info .dj-price,.cart-info .num-pro,.cart-info .zj-price,.cart-info .cz {float:left;
}
.cart-info {height:40px;line-height:40px;background-color:#EFEFEF;
}
.cart-info .all {width:80px;padding:0px 15px;
}
.cart-info .all input {margin-right:8px;
}
.cart-info .pro-info {width:500px;
}
.cart-info .dj-price {width:80px;
}
.cart-info .num-pro {width:120px;
}
.cart-info .zj-price {width:110px;
}
.cart-info .cz {width:80px;
}
.cart-main {margin-top:15px;
}
.cart-item {border:1px solid #EFEFEF;padding:15px;overflow:hidden;margin-bottom:15px;
}
.cart-j {width:30px;
}
.pro-item {width:560px;
}
.pro-item .pro-img {width:80px;height:80px;
}
.pro-item .pro-title {width:225px;line-height:1.8;padding:0px 15px;
}
.pro-item .pro-gg {width:185px;padding:0px 15px;font-size:10px;color:#666;
}
.price-g {width:80px;color:black;font-weight:bold;
}
.price-num {width:95px;margin-right:30px;background-color:#EFEFEF;/* border:1px solid #EFEFEF;*/
}
.price-num .increment,.price-num .decrement {width:20px;float:left;text-align:center;
}
.price-num .num {float:left;width:50px;text-align:center;
}
.price-jiner{width:110px;color:red;font-weight:bold;
}
.price-caozuo {width:40px;
}
.priceAll {margin:0px 20px;
}
.priceAll span {padding:0px 8px;color:#f22d00;font-weight:bold;font-size:15px;
}
.spnum em {font-style:normal;padding:0px 8px;color:#f22d00;font-weight:bold;font-size:15px;
}
.js-btn {display:block;width:100px;text-align:center;background-color:#f22d00;color:white;
}
.pro-item img {width:80px;
}

html代码:

<!DOCTYPE html>
<html>
<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><link rel="stylesheet" type="text/css" href="css/carstyle.css"><script src="js/jquery-3.6.0.js"></script>
</head>
<!--https://blog.csdn.net/qq_41801219/article/details/116065244-->
<body>
<div class="pro-main"><div class="cart-info"><div class="all"><input type="checkbox" class="allCheck">全选</div><div class="pro-info">商品信息</div><div class="dj-price">单价</div><div class="num-pro">数量</div><div class="zj-price">金额</div><div class="cz">操作</div></div><div class="cart-main"><div class="cart-item"><div class="cart-j fl"><input type="checkbox" class="j-check" ></div><div class="pro-item fl"><div class="pro-img fl"><img src="https://www.jq22.com/img/cs/500x500-1.png" alt=""></div><div class="pro-title fl">西部数据(WD)蓝盘 1TB1</div><div class="pro-gg fl">SATA6Gb/s 7200转64MB 台式机械硬盘(WD10EZEX)</div></div><div class="price-g fl">¥28.60</div><div class="price-num fl"><a href="javascript:;" class="increment">+</a><input type="text" value="1" readonly="readonly" class="num"><a href="javascript:;" class="decrement">-</a></div><div class="price-jiner fl">¥28.60</div><div class="price-caozuo fl"><a href="#" class="del-d">删除</a></div></div><div class="cart-item"><div class="cart-j fl"><input type="checkbox" class="j-check"></div><div class="pro-item fl"><div class="pro-img fl"><img src="https://www.jq22.com/img/cs/500x500-1.png" alt=""></div><div class="pro-title fl">西部数据(WD)蓝盘 1TB2</div><div class="pro-gg fl">SATA6Gb/s 7200转64MB 台式机械硬盘(WD10EZEX)</div></div><div class="price-g fl">¥40.50</div><div class="price-num fl"><a href="javascript:;" class="increment">+</a><input type="text" value="1" readonly="readonly" class="num"><a href="javascript:;" class="decrement">-</a></div><div class="price-jiner fl" id="price">¥40.50</div><div class="price-caozuo fl"><a href="javascript:;" class="del-d">删除</a></div></div><div class="cart-item"><div class="cart-j fl"><input type="checkbox" class="j-check"></div><div class="pro-item fl"><div class="pro-img fl"><img src="https://www.jq22.com/img/cs/500x500-1.png" alt=""></div><div class="pro-title fl">西部数据(WD)蓝盘 1TB3</div><div class="pro-gg fl">SATA6Gb/s 7200转64MB 台式机械硬盘(WD10EZEX)</div></div><div class="price-g fl">¥29.60</div><div class="price-num fl"><a href="javascript:;" class="increment">+</a><input type="text" value="1" readonly="readonly"  class="num"><a href="javascript:;" class="decrement">-</a></div><div class="price-jiner fl" >¥29.60</div><div class="price-caozuo fl"><a href="javascript:;" class="del-d">删除</a></div></div></div><div class="cart-info"><div class="all fl">&nbsp;&nbsp;&nbsp;&nbsp;</div><div class="fl"><a href="#" class="clearAll">批量删除</a></div><div class="fr" style="width: 500px;"><div class="spnum fl">已选商品<em>0</em>件</div><div class="priceAll fl">合计(不含运费): <span>0.00 元</span></div><div class="jiesuan fr"><a href="#" class="js-btn">结算</a></div></div></div>
</div></body>
</html>

js代码:

<script>$(function (){/*点击全选按钮复选框*/$(".allCheck").change(function (){if ($(".allCheck").prop("checked")){$(".j-check").prop("checked",true);}else{$(".j-check").prop("checked",false);}allprice();allgoods();})//当取消一个复选框的选中,那就取消全选复选框的选中$(".j-check").change(function (){allprice();allgoods();$.each($(".j-check"),function (e,domE){if ($(domE).prop("checked")==false){$(".allCheck").prop("checked",false);}})})/*复选框发生改变*/$(".j-check").change(function (){allprice();allgoods();var num=0;$.each($(".j-check"),function (){if (!$(this).prop("checked")){num+=1;}})if (num==0){$(".allCheck").prop("checked",true);}})var num=1;//去除指定字符var reg=new RegExp("¥");/*数量增加*/$(".increment").click(function (){var nums=parseInt($(this).siblings(".num").val())+num;//添加数量$(this).siblings(".num").val(parseInt(nums));var price=parseFloat($(this).parent(".price-num").siblings(".price-g").html().replace(reg,"")).toFixed(2)$(this).parent(".price-num").siblings(".price-jiner").html("¥"+parseFloat(nums*price).toFixed(2));allprice();allgoods();})/*数量减少*/$(".decrement").click(function (){var nums=parseInt($(this).siblings(".num").val())-num;//获取当前货物的单价var price=parseFloat($(this).parent(".price-num").siblings(".price-g").html().replace(reg,"")).toFixed(2)if (parseInt($(this).siblings(".num").val())>1){$(this).siblings(".num").val(nums);$(this).parent(".price-num").siblings(".price-jiner").html("¥"+parseFloat(nums*price).toFixed(2));}else{confirm("数量不可减少!!");}allprice();allgoods();})/**//*删除一个货物*/$(".del-d").click(function (){if ($(this).parent(".price-caozuo").siblings(".cart-j").children(".j-check").prop("checked")){$(this).parent(".price-caozuo").parent(".cart-item").remove();allprice();allgoods();}else{confirm("请勾选要删除宝贝!!");}})/*批量删除宝贝*/$(".clearAll").click(function (){var i=0;$(".j-check").each(function (e,domE){if ($(domE).prop("checked")){i++;$(domE).parent(".cart-j").parent(".cart-item").remove();}})allprice();allgoods();/*判断是否选中删除的货物*/if (i==0){confirm("请选中要删除的货物!!!")}})/*总价格*/function allprice(){var all=0;$(".j-check").each(function (){if ($(this).prop("checked")){var price=parseFloat($(this).parent(".cart-j").siblings(".price-jiner").html().replace(reg,"")).toFixed(2);all=parseFloat(all)+parseFloat(price);}})if (all==0){$(".priceAll").children("span").html('0.00 元')}else{$(".priceAll").children("span").html(parseFloat(all).toFixed(2)+" 元")}}/*结算,清除购物车要结算的商品*/$(".js-btn").click(function () {var i=0;$(".j-check").each(function (e,domE){if ($(domE).prop("checked")){i++;}})/*判断是否选中删除的货物*/if (i==0){confirm("请选中要购买的商品!!!")}else{if(confirm("请确认是否要支付")==true){$(".j-check").each(function (e,domE){if ($(domE).prop("checked")){i++;$(domE).parent(".cart-j").parent(".cart-item").remove();/*此处应有一个ajax将数据传入后台并跳转界面*/}})confirm("您已下单,宝贝正在运送的途中,请耐心等待");}}allprice();allgoods();})})/*商品总件数*/function allgoods(){var allgoods=0;$(".j-check").each(function (){if ($(this).prop("checked")){var goods=parseInt($(this).parent(".cart-j").siblings(".price-num").children(".num").val());allgoods=parseInt(allgoods)+parseInt(goods);console.log(parseInt(allgoods));}})if (allgoods==0){$(".spnum").children("em").html('0');}else {$(".spnum").children("em").html(parseInt(allgoods));}}</script>

其实实现简单的js+html购物车功能,无非是判断哪一个物品类被点击,根据被点击的类名来实现点击事件,并且通过当前的类名来查找当前类名的父类或者兄弟类,从而可以与其他控件实现交互功能!!

js+html实现购物车功能相关推荐

  1. js代码 实现购物车功能

    @购物车 <!DOCTYPE html> <html><head><meta charset="utf-8" /><title ...

  2. js购物车功能php,使用JS实现购物车功能步骤详解

    这次给大家带来使用JS实现购物车功能步骤详解,使用JS实现购物车功能的注意事项有哪些,下面就是实战案例,一起来看一下. 我们肯定都很熟悉商品购物车这一功能,每当我们在某宝某东上购买商品的时候,看中了哪 ...

  3. js购物车功能php,实战项目:用原生JS实现一个购物车的功能

    实战:购物车功能 一.两个实用的数组函数 1.1 Array.every() every()方法传入回调函数,这个回调函数有三个参数,分别是: item:用于测试的当前值: index:当前测试值的索 ...

  4. JS实现购物车功能(JS案例)

    整理了一下当时学js写的一些案例,觉得购物车功能在一般网站比较常见且基础,现在把它整理出来,需要的小伙伴可以参考一下. 该案例购物车主要功能如下: 1. 商品单选.全选.反选功能 2. 商品添加.删除 ...

  5. 微信小程序之购物车功能

    前言 以往的购物车,基本都是通过大量的 DOM 操作来实现.微信小程序其实跟 vue.js 的用法非常像,接下来就看看小程序可以怎样实现购物车功能. 需求 先来弄清楚购物车的需求. 单选.全选和取消, ...

  6. 小程序判断数组的index是否为空_微信小程序之购物车功能(仅学习)

    购物车,基本都是通过大量的 DOM 操作来实现.微信小程序其实跟 vue.js 的用法非常像,接下来就看看小程序可以怎样实现购物车功能. 需求 先来弄清楚购物车的需求. 单选.全选和取消,而且会随着选 ...

  7. vue实战记录(二)- vue实现购物车功能之创建vue实例

    vue实战,一步步实现vue购物车功能的过程记录,课程与素材来自慕课网,自己搭建了express本地服务器来请求数据 作者:狐狸家的鱼 本文链接:vue实战-实现购物车功能(二) GitHub:sue ...

  8. java代码实现购物车小程序_使用Taro实现小程序商城的购物车功能模块的实例代码...

    Taro 是一套遵循 React 语法规范的 多端开发 解决方案. 现如今市面上端的形态多种多样,Web.React-Native.微信小程序等各种端大行其道,当业务要求同时在不同的端都要求有所表现的 ...

  9. 042——VUE中组件之子组件使用$on与$emit事件触发父组件实现购物车功能

    <!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8" ...

最新文章

  1. Nginx问题定位之监控进程异常退出
  2. 苹果内存取证工具volafox
  3. python如何计算分子描述符_Python——描述符(descriptor)解密
  4. 每个人都有自己的人生节奏
  5. ***ECharts图表入门和最佳实践
  6. layui实现select下拉选择框组件(含代码、案例、截图)
  7. spring定时每天早上八点_SpringBoot 如何实现并发定时任务?
  8. [CQOI2014]数三角形 题解(找规律乱搞)
  9. cs-Filters
  10. 【概念理论】不存在的NOIP2016
  11. ELK——Logstash 2.2 mutate 插件【翻译+实践】
  12. tcp服务器修改端口号,RAKsmart服务器:Windows修改远程端口号的图文教程
  13. 第五届世界互联网大会 乌镇新“网事” 世界新期待
  14. S3DIS场景点云数据集
  15. 复变函数基本概念总结
  16. 【MNN学习六】基于Android的MNN编译安装
  17. 湖泊遥感研究进展(概述)
  18. Racket编程指南——8 输入和输出
  19. 中文信息处理——纵览与建议
  20. 苹果iPhone6为何拯救不了富士康?

热门文章

  1. Linux 2.6.19.x 内核编译配置选项简介(转)
  2. turbine java_微服务搭建集成Spring Cloud Turbine详解
  3. 中国企业怎么转型成为互联网模式的公司
  4. VMWare修改MAC地址
  5. 文档/图片/视屏/音频在线格式转换工具(实用,免费)
  6. linux如何调试elf程序,Linux下ELF的执行过程
  7. Wimax和WI-FI比较
  8. 搜索引擎判断网页页面价值的标准
  9. java注释还能运行_老师,你确定Java注释不会被执行吗?
  10. gff文件_GFF文件格式简介