JS实现购物车基本功能


Posted in Javascript onNovember 08, 2020

JS实现购物车商品 加、减、单选、全选、删除、手动输入、价格更新等功能,供大家参考,具体内容如下

JS实现购物车基本功能

JavaScript代码

$(function(){
 
 $("#footer").hover(function(){
 $("#footer").css({"border":"#e00"})
 },)
 
 var inputs=document.getElementsByName("good-id");
 var all=document.getElementsByName("all")[0];
 
 all.onclick=function(){
 for(var i=0;i<inputs.length;i++){
 inputs[i].checked=this.checked;
 }
 sumprice();
 }
 
 for(var i=0;i<inputs.length;i++){
 inputs[i].onclick=function(){
 var count=0;
 for(var j=0;j<inputs.length;j++){
 if(inputs[j].checked==true){
 count++
 }
 }
 if(count<inputs.length){
 all.checked=false;
 }else{
 all.checked=true;
 }
 sumprice();
 }
 }
 
 //减少
 var minus=document.getElementsByName("minus");
 for(var i=0;i<minus.length;i++){
 minus[i].onclick=function(){
 var counts=this.nextElementSibling;
 var count=parseInt(counts.value);
 if(count>1){
 counts.value=--count;
 }
 sumprice();
 }
 }
 //增加
 var plus=document.getElementsByName("plus");
 for(var i=0;i<plus.length;i++){
 plus[i].onclick=function(){
 var counts=this.previousElementSibling;
 var count=parseInt(counts.value);
 counts.value=++count;
 sumprice();
 }
 }
 
 //手动输入
 var counts=document.getElementsByName("count");
 for(var i=0;i<counts.length;i++){
 counts[i].onblur=function(){
 var count=parseInt(this.value);
 if(isNaN(count)||count<1){
 count=1;
 }
 this.value=count;
 sumprice();
 }
 }
 
 
 //计算
function sumprice() {
 var tbody = document.getElementById("cart-goods-list");
 var tbodyTr = tbody.getElementsByTagName("tr");
 var sumprice=0;
 for(var i = 0; i < tbodyTr.length; i++) {
 //获取单价
 var priceEm = tbodyTr[i].getElementsByClassName("price-em")[0];
 var price = parseFloat(priceEm.innerText);

 //获取数量
 var counts = tbodyTr[i].getElementsByClassName("combo-value")[0];
 var count = parseInt(counts.value);
 //乘积
 var chengji=price*count;
 //把乘积弄到金额里面
 var amountEm=tbodyTr[i].getElementsByClassName("amount-em")[0];
 amountEm.innerText=chengji.toFixed(2);
 
 //获取单选框
 var liD=tbodyTr[i].getElementsByTagName("input")[0];
 if(liD.checked){
 sumprice+=chengji;
 }
 }
 var zong=document.getElementById("total-amount-em");
 zong.innerText=sumprice.toFixed(2);
}
 
 //删除
 document.getElementById("cart-delete").onclick=function(){
 var tbody = document.getElementById("cart-goods-list");
 var del=[];
 for(var i=0;i<inputs.length;i++){
 if(inputs[i].checked){
 del.push(inputs[i].parentElement.parentElement);
 }
 }
 for(var i=0;i<del.length;i++){
 tbody.removeChild(del[i]);
 }
 all.checked=false;
 sumprice();
 }
 
 document.getElementById("total-amount").onmouseover=function(){
 document.getElementById("total-amount").style.cursor="pointer";
 }
 
 document.getElementById("total-amount").onclick=function(){
 var tbody = document.getElementById("cart-goods-list");
 var tr=document.createElement("tr");
 tr.innerHTML='<tr><td><input type="checkbox" name="good-id" value="1"></td><td class="goods"><div class="goods-image"><img src="./pic/goods/1.jpg"></div><div class="goods-information"><h3>Dior 迪奥 花漾甜心小姐 女士淡香水</h3><ul><li>50毫升</li><li>不支持7天无理由退货</li></ul></div></td><td><span class="price">¥<em class="price-em">498.00</em></span></td><td><div class="combo"><input type="button" name="minus" value="-" class="combo-minus"><input type="text" name="count" value="1" class="combo-value"><input type="button" name="plus" value="+" class="combo-plus"></div></td><td><strong class="amount">¥<em class="amount-em">498.00</em></strong></td></tr>';
 tbody.appendChild(tr);
 }
})

CSS代码

@charset "utf-8";

#main{
 padding: 30px 0px;
}

#cart{
 background: #FFFFFF;
 padding: 40px;
}

#cart h1{
 line-height: 40px;
 padding: 0px 0px 10px 0px;
}

table.form{
 border-collapse: collapse;
 empty-cells: show;
 margin: 20px 0px;
 padding: 0px;
 table-layout: fixed;
 width: 100%;
}

table.form th,
table.form td{
 border-bottom: 1px solid #DDDDDD;
 padding: 15px 10px;
 text-align: left;
}

table.form{
 border-top: 3px solid #DDDDDD;
}

.goods .goods-image img{
 border: 1px solid #DDDDDD;
 float: left;
 height: 100px;
 margin: 0px 20px 0px 0px;
}

.goods .goods-information{
 float: left;
}

.goods .goods-information ul{
 color: #666666;
 font-size: 12px;
 line-height: 20px;
 margin:10px 0px 0px 0px;
}

.price,
.amount,
#total-amount{
 color: #E00000;
}

#total-amount{
 font-size: 22px;
}

.price em,
.amount em,
#total-amount em{
 font-style: normal;
}

.combo .combo-minus,
.combo .combo-value,
.combo .combo-plus{
 background: #FFFFFF;
 border: 1px solid #DDDDDD;
 color: #333333;
 float: left;
 font-weight: bold;
 margin: 0px;
 outline: none;
 text-align: center;
}

.combo .combo-minus,
.combo .combo-plus{
 font-size: 16px;
 height: 26px;
 line-height: 26px;
 padding: 0px;
 width: 24px;
}

.combo .combo-value{
 border-left: none;
 border-right: none;
 height: 20px;
 line-height: 20px;
 padding: 2px;
 width: 40px;
}

#cart-delete{
 margin-left: 20px;
}

#settlement{
 background: #E00000;
 border: none;
 color: #FFFFFF;
 float: right;
 font-size: 16px;
 height: 40px;
 line-height: 40px;
 margin: 0px;
 outline: none;
 padding: 0px;
 width: 160px;
}

HTML代码

<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8">
 <title>商城</title>
 <link rel="stylesheet" href="./css/common.css" rel="external nofollow" >
 <link rel="stylesheet" href="./iconfont/iconfont.css" rel="external nofollow" >
 <link rel="stylesheet" href="./css/cart.css" rel="external nofollow" >
 <script type="text/javascript" src="js/jquery-3.1.1.js"></script>
 <script type="text/javascript" src="./js/cart2.js"></script>
 </head>
 <body>
 <div id="topbar">
 <div class="container">
 <div id="topbar-location">
 <i class="iconfont icon-location"></i>
 <a href="#">北京</a>
 </div>
 <div id="topbar-menu">
 <ul>
 <li>
 <a href="#"class="red">登录</a>
 </li>
 <li class="separator">|</li>
 <li>
 <a href="./register.html" rel="external nofollow" >免费注册</a>
 </li>
 <li class="separator">|</li>
 <li>
 <a href="#">我的订单</a>
 </li>
 <li class="separator">|</li>
 <li>
 <a href="#">收藏夹</a>
 </li>
 <li class="separator">|</li>
 <li>
 <a href="#">帮助中心</a>
 </li>
 </ul>
 </div>
 </div>
 </div>
 <div id="header">
 <div class="container">
 <div id="header-logo">
 <a href="./index.html" rel="external nofollow" >
 <h1>LOGO</h1>
 </a>
 </div>
 <div id="header-search">
 <div id="header-search-combobox">
 <form action="#" method="post">
 <input type="text" name="keywords" placeholder="搜索" id="header-search-combobox-text">
 <button type="submit" id="header-search-combobox-button">
 <i class="iconfont icon-search"></i>
 </button>
 </form>
 </div>
 <div class="clear">
 <ul id="header-search-hotkeywords">
 <li>
 <strong>热搜:</strong>
 </li>
 <li>
 <a href="#">笔记本</a>
 </li>
 <li class="separator">|</li>
 <li>
 <a href="#">平板</a>
 </li>
 <li class="separator">|</li>
 <li>
 <a href="#">手机</a>
 </li>
 <li class="separator">|</li>
 <li>
 <a href="#">墨盒</a>
 </li>
 </ul>
 <a href="#"id="header-search-advancedsearch">高级搜索</a>
 </div>
 </div>
 <div id="header-cart">
 <i class="iconfont icon-cart"></i>
 <a href="#">购物车</a>
 <strong>0</strong>
 </div>
 </div>
 </div>
 <div id="navigation">
 <div class="container">
 <div id="navigation-category">
 <div id="navigation-category-heading">
 <div class="float-left">
 <i class="iconfont icon-menu"></i>
 <strong>全部商品分类</strong>
 </div>
 <div class="float-right">
 <i class="iconfont icon-dropdown"></i>
 </div>
 </div>
 <div id="navigation-category-content">
 <dl>
 <dt>美容彩妆</dt>
 <dd>
 <a href="#">护肤</a>
 <em>|</em>
 <a href="#">面膜</a>
 <em>|</em>
 <a href="#">防晒</a>
 <em>|</em>
 <a href="#">彩妆</a>
 <em>|</em>
 <a href="#">香水</a>
 </dd>
 </dl>
 <dl>
 <dt>服饰箱包</dt>
 <dd>
 <a href="#">大牌</a>
 <em>|</em>
 <a href="#">服饰</a>
 <em>|</em>
 <a href="#">箱包</a>
 <em>|</em>
 <a href="#">配饰</a>
 <em>|</em>
 <a href="#">鞋履</a>
 </dd>
 </dl>
 <dl>
 <dt>数码家电</dt>
 <dd>
 <a href="#">手机</a>
 <em>|</em>
 <a href="#">生活</a>
 <em>|</em>
 <a href="#">厨房</a>
 <em>|</em>
 <a href="#">数码</a>
 <em>|</em>
 <a href="#">办公</a>
 </dd>
 </dl>
 <dl>
 <dt>家居个护</dt>
 <dd>
 <a href="#">洗护</a>
 <em>|</em>
 <a href="#">居家</a>
 <em>|</em>
 <a href="#">女性</a>
 <em>|</em>
 <a href="#">宠物</a>
 <em>|</em>
 <a href="#">家纺</a>
 </dd>
 </dl>
 <dl>
 <dt>运动户外</dt>
 <dd>
 <a href="#">运动服饰</a>
 <em>|</em>
 <a href="#">运动鞋</a>
 <em>|</em>
 <a href="#">户外服饰</a>
 <em>|</em>
 <a href="#">户外鞋靴</a>
 <em>|</em>
 <a href="#">户外装备</a>
 </dd>
 </dl>
 <dl>
 <dt>环球美食</dt>
 <dd>
 <a href="#">饮品</a>
 <em>|</em>
 <a href="#">零食</a>
 <em>|</em>
 <a href="#">粮油</a>
 <em>|</em>
 <a href="#">糕点</a>
 </dd>
 </dl>
 </div>
 </div>
 <div id="navigation-menu">
 <ul>
 <li>
 <a href="#">促销</a>
 </li>
 <li>
 <a href="#">秒杀</a>
 </li>
 <li>
 <a href="#">优惠券</a>
 </li>
 </ul>
 </div>
 </div>
 </div>
 <div id="main">
 <div class="container">
 <div id="cart">
 <h1>购物车</h1>
 <form action="#" method="post">
 <table class="form">
 <thead>
 <tr>
 <th width="8%">选择</th>
 <th width="50%">商品</th>
 <th width="13%">单价(元)</th>
 <th width="15%">数量</th>
 <th width="14%">金额(元)</th>
 </tr>
 </thead>
 <tbody id="cart-goods-list">
 <tr>
 <td>
 <input type="checkbox" name="good-id" value="1">
 </td>
 <td class="goods">
 <div class="goods-image">
 <img src="./pic/goods/1.jpg">
 </div>
 <div class="goods-information">
 <h3>Dior 迪奥 花漾甜心小姐 女士淡香水</h3>
 <ul>
 <li>50毫升</li>
 <li>不支持7天无理由退货</li>
 </ul>
 </div>
 </td>
 <td>
 <span class="price">¥<em class="price-em">498.00</em></span>
 </td>
 <td>
 <div class="combo">
 <input type="button" name="minus" value="-" class="combo-minus">
 <input type="text" name="count" value="1" class="combo-value">
 <input type="button" name="plus" value="+" class="combo-plus">
 </div>
 </td>
 <td>
 <strong class="amount">¥<em class="amount-em">498.00</em></strong>
 </td>
 </tr>
 <tr>
 <td>
 <input type="checkbox" name="good-id" value="2">
 </td>
 <td class="goods">
 <div class="goods-image">
 <img src="./pic/goods/3.jpg">
 </div>
 <div class="goods-information">
 <h3>LANCÔME 兰蔻 嫩肌活肤精华肌底液</h3>
 <ul>
 <li>50毫升</li>
 <li>不支持7天无理由退货</li>
 </ul>
 </div>
 </td>
 <td>
 <span class="price">¥<em class="price-em">598.00</em></span>
 </td>
 <td>
 <div class="combo">
 <input type="button" name="minus" value="-" class="combo-minus">
 <input type="text" name="count" value="1" class="combo-value">
 <input type="button" name="plus" value="+" class="combo-plus">
 </div>
 </td>
 <td>
 <strong class="amount">¥<em class="amount-em">598.00</em></strong>
 </td>
 </tr>
 </tbody>
 <tfoot>
 <tr>
 <td colspan="2">
 <label>
 <input type="checkbox" name="all">
 <span>全选</span>
 </label>
 <a href="#"id="cart-delete">删除</a>
 </td>
 <td colspan="3">
 <span>合计:</span>
 <strong id="total-amount">¥<em id="total-amount-em">0.00</em></strong>
 <input type="submit" value="立即结算" id="settlement">
 </td>
 </tr>
 </tfoot>

 </table>
 </form>
 </div>
 </div>
 </div>
 <div id="footer">
 <div id="footer-promise">
 <div class="container clear">
 <div class="footer-promise-column clear">
 <img src="./img/1.png">
 <dl>
 <dt>100%正品</dt>
 <dd>正品保障 假一赔十</dd>
 </dl>
 </div>
 <div class="footer-promise-column clear">
 <img src="./img/2.png">
 <dl>
 <dt>无忧退货</dt>
 <dd>国内退货 售后无忧</dd>
 </dl>
 </div>
 <div class="footer-promise-column clear">
 <img src="./img/3.png">
 <dl>
 <dt>低价保障</dt>
 <dd>缩减环节 确保低价</dd>
 </dl>
 </div>
 <div class="footer-promise-column clear">
 <img src="./img/4.png">
 <dl>
 <dt>海外发货</dt>
 <dd>海外直邮 闪电发货</dd>
 </dl>
 </div>
 </div>
 </div>
 <div id="footer-link">
 <div class="container clear">
 <div class="footer-link-column">
 <h3>购物指南</h3>
 <ul>
 <li>
 <a href="#" >购物流程</a>
 </li>
 <li>
 <a href="#" >发票制度</a>
 </li>
 <li>
 <a href="#" >账户管理</a>
 </li>
 <li>
 <a href="#" >会员优惠</a>
 </li>
 </ul>
 </div>
 <div class="footer-link-column">
 <h3>支付方式</h3>
 <ul>
 <li>
 <a href="#" >货到付款</a>
 </li>
 <li>
 <a href="#" >网上支付</a>
 </li>
 <li>
 <a href="#" >礼 品 卡</a>
 </li>
 <li>
 <a href="#" >银行转账</a>
 </li>
 </ul>
 </div>
 <div class="footer-link-column">
 <h3>订单服务</h3>
 <ul>
 <li>
 <a href="#" >配送查询</a>
 </li>
 <li>
 <a href="#" >状态说明</a>
 </li>
 <li>
 <a href="#" >取消订单</a>
 </li>
 <li>
 <a href="#" >修改订单</a>
 </li>
 </ul>
 </div>
 <div class="footer-link-column">
 <h3>配送方式</h3>
 <ul>
 <li>
 <a href="#" >配送范围</a>
 </li>
 <li>
 <a href="#" >免邮标准</a>
 </li>
 <li>
 <a href="#" >订单自提</a>
 </li>
 <li>
 <a href="#" >验货签收</a>
 </li>
 </ul>
 </div>
 <div class="footer-link-column">
 <h3>售后服务</h3>
 <ul>
 <li>
 <a href="#" >售后政策</a>
 </li>
 <li>
 <a href="#" >价格保护</a>
 </li>
 <li>
 <a href="#" >退款说明</a>
 </li>
 <li>
 <a href="#" >退 换 货</a>
 </li>
 </ul>
 </div>
 </div>
 </div>
 <div id="footer-menu">
 <ul>
 <li>
 <a href="#" >关于我们</a>
 </li>
 <li class="separator">|</li>
 <li>
 <a href="#" >服务条款</a>
 </li>
 <li class="separator">|</li>
 <li>
 <a href="#" >隐私保护</a>
 </li>
 <li class="separator">|</li>
 <li>
 <a href="#" >联系我们</a>
 </li>
 <li class="separator">|</li>
 <li>
 <a href="#" >帮助中心</a>
 </li>
 </ul>
 </div>
 <div id="footer-copyright">
 <p>Copyright © 2016 XXX. All Rights Reserved.</p>
 </div>
 </div>
 </body>

</html>

注:CSS样式代码由于太多上面没有给全,只给了主要代码。小伙伴们可以根据实际情况修改样式。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js的event详解。
Sep 06 Javascript
优化 JavaScript 代码的方法小结
Jul 16 Javascript
getJSON调用后台json数据时函数被调用两次的原因猜想
Sep 29 Javascript
Javascript实现计算个人所得税
May 10 Javascript
Javascript中String的常用方法实例分析
Jun 13 Javascript
JavaScript去除数组里重复值的方法
Jul 13 Javascript
JQuery中Ajax()的data参数类型实例分析
Dec 15 Javascript
js如何编写简单的ajax方法库
Aug 02 Javascript
ES6解构赋值实例详解
Oct 31 Javascript
vue2.0+vue-dplayer实现hls播放的示例
Mar 02 Javascript
微信小程序时间标签和时间范围的联动效果
Feb 15 Javascript
利用js实现简易红绿灯
Oct 15 Javascript
Vue实现购物车基本功能
Nov 08 #Javascript
vue实现顶部菜单栏
Nov 08 #Javascript
Vue实现菜单切换功能
Nov 08 #Javascript
JS使用setInterval计时器实现挑战10秒
Nov 08 #Javascript
JS实现手风琴特效
Nov 08 #Javascript
JS画布动态实现黑客帝国背景效果
Nov 08 #Javascript
vue.js页面加载执行created,mounted的先后顺序说明
Nov 07 #Javascript
You might like
PHP 命令行工具 shell_exec, exec, passthru, system详细使用介绍
2011/09/11 PHP
php中时间轴开发(刚刚、5分钟前、昨天10:23等)
2011/10/03 PHP
PHP实现把数字ID转字母ID
2013/08/12 PHP
PHP防止跨域提交表单
2013/11/01 PHP
PHP关于htmlspecialchars、strip_tags、addslashes的解释
2014/07/04 PHP
php版银联支付接口开发简明教程
2016/10/14 PHP
PHP函数积累总结
2019/03/19 PHP
laravel ORM关联关系中的 with和whereHas用法
2019/10/16 PHP
php判断某个方法是否存在函数function_exists (),method_exists()与is_callable()区别与用法解析
2020/04/20 PHP
JavaScript 学习 - 提高篇
2007/02/02 Javascript
使用js实现一个可编辑的select下拉列表
2014/02/20 Javascript
JS简单实现动画弹出层效果
2015/05/05 Javascript
JavaScript编程的单例设计模讲解
2015/11/10 Javascript
JS实现的幻灯片切换显示效果
2016/09/07 Javascript
微信小程序开发经验总结(推荐)
2017/01/11 Javascript
Vue 2.0+Vue-router构建一个简单的单页应用(附源码)
2017/03/14 Javascript
Ionic3 UI组件之Gallery Modal详解
2017/06/07 Javascript
vue.js 双层嵌套for遍历的方法详解, 类似php foreach()
2018/09/07 Javascript
JS实现继承的几种常用方式示例
2019/06/22 Javascript
在node环境下parse Smarty模板的使用示例代码
2019/11/15 Javascript
微信小程序利用for循环解决内容变更问题
2020/03/05 Javascript
JavaScript实现拖动对话框效果的实现代码
2020/10/12 Javascript
python中的__init__ 、__new__、__call__小结
2014/04/25 Python
python交互式图形编程实例(一)
2017/11/17 Python
python 将列表中的字符串连接成一个长路径的方法
2018/10/23 Python
Python 控制终端输出文字的实例
2019/07/12 Python
Python面向对象之多态原理与用法案例分析
2019/12/30 Python
Python3.6 + TensorFlow 安装配置图文教程(Windows 64 bit)
2020/02/24 Python
python 调用API接口 获取和解析 Json数据
2020/09/28 Python
公司周年庆典邀请函
2014/01/12 职场文书
工程力学专业自荐信范文
2014/03/17 职场文书
中班上学期幼儿评语
2014/04/30 职场文书
校园安全学习心得体会
2016/01/18 职场文书
React 高阶组件HOC用法归纳
2021/06/13 Javascript
Oracle以逗号分隔的字符串拆分为多行数据实例详解
2021/07/16 Oracle
TV动画《史上最强大魔王转生为村民A》番宣CM公布
2022/04/01 日漫