css

    *{font-style: normal}
.gw{margin: 8px;}
.gw::after{display: block;clear: both;content: '';margin: 10px;}
.gw_num{border: 1px solid #dbdbdb;width: 110px;line-height: 26px;overflow: hidden;float: left;}
.gw_num em{display: block;height: 26px;width: 26px;float: left;color: #7A7979;border-right: 1px solid #dbdbdb;text-align: center;cursor: pointer;font-style: normal}
.gw_num .num{display: block;float: left;text-align: center;width: 52px;font-style: normal;font-size: 14px;line-height: 24px;border: 0;}
.gw_num em.add{float: right;border-right: 0;border-left: 1px solid #dbdbdb;}
p{margin: 4px;padding: 0}
.choose,.qx{float: left;width: 20px;height: 20px;border: 1px solid #ccc; border-radius: 100%;margin-right: 10px;}
.choose-on, .qx-on{background: url(./on.png) no-repeat center center;background-size: 100%;}
    <div class="zong">
<div class="gw">
<div class="choose"></div>
<div class="gw_num">
<em class="jian">-</em>
<input type="text" value="0" class="num"/>
<em class="add">+</em>
</div>
<p>单价<i>20</i>元 总金额:¥<span>0</span></p>
<div class="del">删除</div>
</div>
<div class="gw">
<div class="choose"></div>
<div class="gw_num">
<em class="jian">-</em>
<input type="text" value="0" class="num"/>
<em class="add">+</em>
</div>
<p>单价<i>40</i>元 总金额:¥<span>0</span></p>
<div class="del">删除</div>
</div>
<div class="gw">
<div class="choose"></div>
<div class="gw_num">
<em class="jian">-</em>
<input type="text" value="0" class="num"/>
<em class="add">+</em>
</div>
<p>单价<i>40</i>元 总金额:¥<span>0</span></p>
<div class="del">删除</div>
</div>
<div class="gw">
<div class="choose"></div>
<div class="gw_num">
<em class="jian">-</em>
<input type="text" value="0" class="num"/>
<em class="add">+</em>
</div>
<p>单价<i>40</i>元 总金额:¥<span>0</span></p>
<div class="del">删除</div>
</div>
<div>
<div class="qx"></div>
<span>全选</span><span class="gs"></span>
<p class="a">金额总计:<span>0</span></p>
</div>
</div>

js

    $(function(){
$('.add').click(function(){
var n = $(this).prev().val()
var num = parseInt(n) + 1;
if(n == 5){num = 5} //设置最大数量 5
$(this).prev().val(num);
var money = $(this).parents('.gw').find('i').text()
var sum = money * num
var p = $(this).parents('.gw').find('span').text(sum)
// console.log(p) // var Sum = $(this).parents('.zong').find('.a > span').text(sum)
// console.log(Sum)
jiesuan()
})
$('.jian').click(function(){
var n = $(this).next().val();
var num = parseInt(n) - 1;
if(n == 0){num = 0} //设置最小数量 0
console.log(num)
$(this).next().val(num);
var money = $(this).parents('.gw').find('i').text()
var sum = money * num
var p = $(this).parents('.gw').find('span').text(sum)
jiesuan()
})
//选中
$('.choose').click(function(){
$(this).toggleClass('choose-on')
// console.log('aa')
jiesuan()
xz()
qx()
})
//全选
$('.qx').click(function(){
$(this).toggleClass('qx-on')
if($(this).is('.qx-on')){
$('.choose').addClass('choose-on')
}else{
$('.choose').removeClass('choose-on')
}
jiesuan()
qx()
}) //删除
$('.del').click(function(){
if(confirm('确定删除商品')){
$(this).parents('.gw').remove()
}
jiesuan()
qx()
// console.log(a) })
}) function jiesuan(){
var num = 0;
// alert('aa')
$('.gw').each(function(){
if($(this).find('.choose').is('.choose-on')){
//获取物品单价
var dj = $(this).find('i').text()
//获取物品数量
var sl = $(this).find('.num').val()
//合计
var hj = dj * sl
num += hj;
} })
$('.a>span').text(num)
} //单选--全选中
function xz(){
var choose = $('.choose')
var choose_on = $('.choose-on')
if(choose.length == choose_on.length){
$('.qx').addClass('qx-on')
}else{
$('.qx').removeClass('qx-on')
}
} //全选
function qx(){
$('.gs').text(' ')
var a = $('.choose-on').length;
$('.gs').text(a)
if(a > 0){
$('.gs').prev().text('已选')
}else{
$('.gs').prev().text('全选')
}
}

jq购物车结算功能的更多相关文章

  1. 原生JS实现购物车结算功能代码+zepto版

    html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3 ...

  2. 微信小程序——购物车结算

    项目需要做个购物车结算功能,先分析需求: 1.全选,反选的功能.当选中的个数 = 购物车的数量时,勾选全选按钮,反之则取消选中全选按钮: 2.改变选中状态时,计算总价和总数量: 3.单个产品的数量加减 ...

  3. 使用jQuery制作一个简易的购物车结算流程

    因为今天下午时候在网上买了东西,在结算界面的时候突发奇想的也想自己动手做一个结算界面,当然了,只是一个最简易的结算界面,有商品数量的加减,有单价和小计,单个多个删除,全选和区县全选等等一些小功能,我在 ...

  4. python3 练习题(用函数完成登录注册以及购物车的功能)

    ''' 用函数完成登录注册以及购物车的功能 作业需求: 1,启动程序,用户可选择四个选项:登录,注册,购物,退出. 2,用户注册,用户名不能重复,注册成功之后,用户名密码记录到文件中. 3,用户登录, ...

  5. JS实现购物车动态功能

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

  6. python实现简单的循环购物车小功能

    python实现简单的循环购物车小功能 # -*- coding: utf-8 -*- __author__ = 'hujianli' shopping = [ ("iphone6s&quo ...

  7. jquery-防多店铺购物车结算全选,单选,及删除,价格计算

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  8. 微信小程序 - 实现购物车结算

    示例源码下载:小程序-实现购物车结算

  9. spring boot:用rocketmq消息订阅实现删除购物车商品功能(spring boot 2.3.3)

    一,为什么要使用消息队列实现删除购物车商品功能? 消息队列主要用来处理不需要立刻返回结果的业务, 常见的例子: 用户在下单后,要清除原购物车中的商品, 这个处理过程不需要马上实现也不需要返回结果给用户 ...

随机推荐

  1. iOS常用的宏定义总结

    字符串是否为空 1   #define kStringIsEmpty(str) ([str isKindOfClass:[NSNull class]] || str == nil || [str le ...

  2. settimeout--原来定时器是有三个及以上参数的

    我平常使用的 settimeout 定时,只知道他有两个参数,一个是function异步成功后的回调函数,一个是delay延时毫秒,今天发现它还可以接着传餐,作为 执行回调函数的参数 语法:var t ...

  3. Codeforces Round #272 (Div. 2) D.Dreamoon and Sets 找规律

    D. Dreamoon and Sets   Dreamoon likes to play with sets, integers and .  is defined as the largest p ...

  4. Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/poi/util/POILogFactory

    Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/poi/util/POILogFacto ...

  5. bzoj 4537 最小公倍数

    给定一张N个顶点M条边的无向图 每条边上带有权值 所有权值都可以分解成2^a*3^b的形式 q个询问,每次询问给定四个参数u.v.a和b,请你求出是否存在一条顶点u到v之间的路径,使得路径依次经过的边 ...

  6. 用回调函数创建一个XMLHttpRequest,并从一个TXT文件中检索数据。

    <script> var xmlhttp; function loadXMLDoc(url,soyo) { if (window.XMLHttpRequest) {// IE7+, Fir ...

  7. vue单页面应用刷新网页后vuex的state数据丢失问题以及beforeunload的兼容性

    最近在用vue写h5项目,当使用window.location重定向页面或者刷新当前页面时, 发现当刷新网页后,保存在vuex实例store里的数据会丢失. 后来在网上查找大神的解决方案如下: exp ...

  8. 【转载】同步与异步--阻塞与非阻塞型I/O

    同步阻塞IO 在这个模型中,应用程序(application)为了执行这个read操作,会调用相应的一个system call,将系统控制权交给kernel,然后就进行等待(这其实就是被阻塞了).ke ...

  9. 【转载】SSH框架总结(框架分析+环境搭建+实例源码下载)

    首先,SSH不是一个框架,而是多个框架(struts+spring+hibernate)的集成,是目前较流行的一种Web应用程序开源集成框架,用于构建灵活.易于扩展的多层Web应用程序. 集成SSH框 ...

  10. P1272 重建道路(树形dp)

    P1272 重建道路 题目描述 一场可怕的地震后,人们用N个牲口棚(1≤N≤150,编号1..N)重建了农夫John的牧场.由于人们没有时间建设多余的道路,所以现在从一个牲口棚到另一个牲口棚的道路是惟 ...