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 相关文章推荐
一个对于Array的简单扩展
Oct 03 Javascript
关于javascript中dataset的问题小结
Nov 16 Javascript
教你一步步用jQyery实现轮播器
Dec 18 Javascript
详解webpack+vue-cli项目打包技巧
Jun 17 Javascript
深入浅析Node环境和浏览器的区别
Aug 14 Javascript
浅谈关于JS下大批量异步任务按顺序执行解决方案一点思考
Jan 08 Javascript
简谈创建React Component的几种方式
Jun 15 Javascript
JS实现移动端双指缩放和旋转方法
Dec 13 Javascript
vue npm install 安装某个指定的版本操作
Aug 11 Javascript
el-form 多层级表单的实现示例
Sep 10 Javascript
nestjs返回给前端数据格式的封装实现
Feb 22 Javascript
js中Map和Set的用法及区别实例详解
Feb 15 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
Oracle Faq(Oracle的版本)
2006/10/09 PHP
PHP中strtotime函数使用方法分享
2012/01/10 PHP
php中session与cookie的比较
2015/01/27 PHP
php 无限分类 树形数据格式化代码
2016/10/11 PHP
一段非常简单的让图片自动切换js代码
2006/11/10 Javascript
javaScript checkbox 全选/反选及批量删除
2010/04/28 Javascript
jquery中实现标签切换效果的代码
2011/03/01 Javascript
JS中令人发指的valueOf方法介绍
2013/02/22 Javascript
js 跳出页面的frameset框架示例介绍
2013/12/23 Javascript
js 金额格式化来回转换示例
2014/02/23 Javascript
js实现表单Radio切换效果的方法
2015/08/17 Javascript
JavaScript中的Object对象学习教程
2016/05/20 Javascript
Angular.js 实现数字转换汉字实例代码
2016/07/14 Javascript
vue.js 双层嵌套for遍历的方法详解, 类似php foreach()
2018/09/07 Javascript
Vuex的基本概念、项目搭建以及入坑点
2018/11/04 Javascript
微信小程序实现侧边栏分类
2019/10/21 Javascript
jQuery实现简易聊天框
2020/02/08 jQuery
深入解读VUE中的异步渲染的实现
2020/06/19 Javascript
js动态生成表格(节点操作)
2021/01/12 Javascript
github配置使用指南
2014/11/18 Python
python按照多个字符对字符串进行分割的方法
2015/03/17 Python
Python打包可执行文件的方法详解
2016/09/19 Python
Python实现树莓派WiFi断线自动重连的实例代码
2017/03/16 Python
Python实现的爬取百度文库功能示例
2019/02/16 Python
python中翻译功能translate模块实现方法
2020/12/17 Python
详解CSS3阴影 box-shadow的使用和技巧总结
2016/12/03 HTML / CSS
canvas粒子动画背景的实现示例
2018/09/03 HTML / CSS
出纳岗位职责
2013/11/09 职场文书
学习委员自我鉴定
2014/01/13 职场文书
个人自我剖析材料
2014/02/07 职场文书
保护环境的建议书
2014/03/12 职场文书
银行金融服务方案
2014/06/11 职场文书
安全生产月宣传标语
2014/10/06 职场文书
试用期解除劳动合同通知书
2015/04/16 职场文书
社交电商模式的兴起:这些新的商机千万别错过
2019/07/26 职场文书
Python连接Postgres/Mysql/Mongo数据库基本操作大全
2021/06/29 Python