js中的DOM模拟购物车功能


Posted in Javascript onMarch 22, 2017

效果图:

js中的DOM模拟购物车功能

代码如下:

<!DOCTYPE html>
<html>
 <head>
 <title> new document </title>
 <meta charset="utf-8">
 <style>
 table{
 border:1px solid #000;
 border-collapse:collapse;
 width:600px;
 }
 td{
 border:1px solid #000;
 text-align:center;
 }
 </style>
 </head>
 <body>
 <table>
 <thead>
 <tr>
 <td>名称</td>
 <td>单价</td>
 <td>数量</td>
 <td>小计</td>
 </tr>
 </thead>
 <tbody id="tbody">
 <tr>
 <td>iphone6</td>
 <td>4488</td>
 <td>
  <button onclick="btnClick(this)">-</button>
  <span>1</span>
  <button onclick="btnClick(this)">+</button>
 </td>
 <td>4488</td>
 </tr>
 <tr>
 <td>iphone6</td>
 <td>5288</td>
 <td>
  <button onclick="btnClick(this)">-</button>
  <span>1</span>
  <button onclick="btnClick(this)">+</button>
 </td>
 <td>5288</td>
 </tr>
 <tr>
 <td>iphone6</td>
 <td>4288</td>
 <td>
  <button onclick="btnClick(this)">-</button>
  <span>1</span>
  <button onclick="btnClick(this)">+</button>
 </td>
 <td>4288</td>
 </tr>
 </tbody>
 <tfoot>
 <td colspan="3" align="right">总计:</td>
 <td id="all_total"></td>
 </tfoot>
 </table>
 <script>
 function btnClick(btn){
 //声明 spanValue 变量,用于保存 span中的数据
 var spanValue;
 //1、更改 span 中的数据
 //1.1 判断 btn 是+还是-
 if(btn.textContent == "+"){
 //1.2 根据 btn 找到 span
 var span=btn.previousElementSibling;
 //1.3 获取 span里的数据
 spanValue=parseInt(span.textContent);
 //1.4 更新 span中的数据
 spanValue+=1;
 span.textContent=spanValue;
 }else{
 //减法操作
 var span = btn.nextElementSibling;
 //1.3 获取 span里的数据
 spanValue=parseInt(span.textContent);
 //1.4 更新 span中的数据
 if(spanValue > 1){
  spanValue-=1;
  span.textContent=spanValue;
 }
 }
 //2.计算 小计
 //2.1 先 获取 单价 元素(tdPrice)
 var tdPrice=btn.parentNode.previousElementSibling;
 //2.2 获取 单价 元素中的 数值(price)
 var price=parseInt(tdPrice.textContent);
 //2.3 计算小计(spanValue*price),保存在 total
 var total=price*spanValue;
 //2.4 获取 小计 元素(tdTotal)
 var tdTotal=btn.parentNode.nextElementSibling;
 //2.5 将 total 的值 赋值给 tdTotal元素
 tdTotal.textContent=total;
 //调用 计算总计 的函数
 calAllTotal();
 }
 /**
 * 计算总计
 */
 function calAllTotal(){
 //1、获取 id为tbody 中的所有tr
 var tbody = document.getElementById("tbody");
 var trs=tbody.getElementsByTagName("tr");
 console.log(trs);
 //2、循环遍历所有tr,找到每个tr的最后一个td
 var all_total=0;
 for(var i=0;i<trs.length;i++){
 var tr=trs[i];
 //3、累加 每个 td 的值 计算总计
 //3.1 获取 tr 中的 最后一个td
 var lastTd=tr.lastElementChild;
 var lastTdValue=parseInt(lastTd.textContent);
 all_total += lastTdValue;
 }
 //4、赋值
 document.getElementById("all_total").textContent=all_total;
 }
 //加载时调用 calAllTotal() 计算现有的总计
 calAllTotal();
 </script>
 </body>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
JQuery实现自定义对话框的代码
Jun 15 Javascript
Extjs入门之动态加载树代码
Apr 09 Javascript
fckeditor粘贴Word时弹出窗口取消的方法
Oct 30 Javascript
jQuery中:focus选择器用法实例
Dec 30 Javascript
JavaScript自定义数组排序方法
Feb 12 Javascript
浅析JS动态创建元素【两种方法】
Apr 20 Javascript
利用JQuery直接调用asp.net后台的简单方法
Oct 27 Javascript
简易Vue评论框架的实现(父组件的实现)
Jan 08 Javascript
深入理解JS异步编程-Promise
Jun 03 Javascript
vue实现树形结构样式和功能的实例代码
Oct 15 Javascript
实例分析javascript中的异步
Jun 02 Javascript
js动态添加带圆圈序号列表的实例代码
Feb 18 Javascript
js+canvas实现动态吃豆人效果
Mar 22 #Javascript
JavaScript实现星星等级评价功能
Mar 22 #Javascript
discuz表情的JS提取方法分析
Mar 22 #Javascript
详解vue2.0组件通信各种情况总结与实例分析
Mar 22 #Javascript
JS简单封装的图片无缝滚动效果示例【测试可用】
Mar 22 #Javascript
Vue计算属性的学习笔记
Mar 22 #Javascript
Angular2实现自定义双向绑定属性
Mar 22 #Javascript
You might like
php str_getcsv把字符串解析为数组的实现方法
2017/04/05 PHP
实例讲解php实现多线程
2019/01/27 PHP
破解Session cookie的方法
2006/07/28 Javascript
使用JS操作页面表格,元素的一些技巧
2007/02/02 Javascript
jquery.ui.progressbar 中文文档
2009/11/26 Javascript
jquery lazyload延迟加载技术的实现原理分析
2011/01/24 Javascript
Jquery焦点与失去焦点示例应用
2014/06/10 Javascript
JavaScript实现计算字符串中出现次数最多的字符和出现的次数
2015/03/12 Javascript
JavaScript提高网站性能优化的建议(二)
2016/07/24 Javascript
Nodejs高扩展性的模板引擎 functmpl简介
2017/02/13 NodeJs
vue父组件中获取子组件中的数据(实例讲解)
2017/09/27 Javascript
weebox弹出窗口不居中显示的解决方法
2017/11/27 Javascript
Vue 获取数组键名的方法
2018/06/21 Javascript
vue element-ui实现input输入框金额数字添加千分位
2019/12/29 Javascript
vue-cli创建的项目中的gitHooks原理解析
2020/02/14 Javascript
Vue+Element自定义纵向表格表头教程
2020/10/26 Javascript
用Javascript实现发送短信验证码间隔功能
2021/02/08 Javascript
Python深入学习之特殊方法与多范式
2014/08/31 Python
Python多线程同步---文件读写控制方法
2019/02/12 Python
python创建n行m列数组示例
2019/12/02 Python
python中使用you-get库批量在线下载bilibili视频的教程
2020/03/10 Python
罗马尼亚购物网站:Vivantis.ro
2019/07/20 全球购物
成教自我鉴定
2013/10/27 职场文书
党员的自我评价范文
2014/01/02 职场文书
通信研究生自荐信
2014/02/01 职场文书
舞蹈比赛获奖感言
2014/02/04 职场文书
护士毕业生自荐信
2014/02/07 职场文书
初中班主任寄语
2014/04/04 职场文书
物理学专业求职信
2014/07/04 职场文书
班主任自我评价范文
2015/03/11 职场文书
原料仓管员岗位职责
2015/04/01 职场文书
党员转正申请报告
2015/05/15 职场文书
Python中Permission denied的解决方案
2021/04/02 Python
Pytest allure 命令行参数的使用
2021/04/18 Python
TV动画《神废柴☆偶像》公布先导PV
2022/03/20 日漫
浅谈MySql update会锁定哪些范围的数据
2022/06/25 MySQL