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 相关文章推荐
js 实现无干扰阴影效果 简单好用(附文件下载)
Dec 27 Javascript
自己动手制作jquery插件之自动添加删除行功能介绍
Oct 14 Javascript
javascript/jquery获取地址栏url参数的方法
Mar 05 Javascript
JavaScript实现鼠标点击后层展开效果的方法
May 13 Javascript
jQuery中常用的遍历函数用法实例总结
Sep 01 Javascript
javascript伸缩型菜单实现代码
Nov 16 Javascript
jQuery中数据缓存$.data的用法及源码完全解析
Apr 29 Javascript
jQuery实现日期联动效果实例
Jul 26 Javascript
React key值的作用和使用详解
Aug 23 Javascript
layui table 列宽百分比显示的实现方法
Sep 28 Javascript
vue遍历生成的输入框 绑定及修改值示例
Oct 30 Javascript
浅谈Vue开发人员的7个最好的VSCode扩展
Jan 20 Vue.js
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
正则表达式语法
2006/10/09 Javascript
解决控件遮挡问题:关于有窗口元素和无窗口元素
2007/01/28 PHP
php数组索引的Key加引号和不加引号的区别
2014/08/19 PHP
php使用timthumb生成缩略图的方法
2016/01/22 PHP
PHP使用SOAP扩展实现WebService的方法
2016/04/01 PHP
非集成环境的php运行环境(Apache配置、Mysql)搭建安装图文教程
2016/04/12 PHP
ext for eclipse插件安装方法
2008/04/27 Javascript
jquery.qrcode在线生成二维码使用示例
2013/08/21 Javascript
jquery 模板的应用示例
2013/11/12 Javascript
Javascript连接多个数组不用concat来解决
2014/03/24 Javascript
js的参数有长度限制吗?发现不能超过2083个字符
2014/04/20 Javascript
JavaScript插件化开发教程 (四)
2015/01/27 Javascript
JS解析XML实例分析
2015/01/30 Javascript
基于JavaScript实现回到页面顶部动画代码
2016/05/24 Javascript
js检测离开或刷新页面时表单数据是否更改的方法
2016/08/02 Javascript
Javascript 判断两个IP是否在同一网段实例代码
2016/11/28 Javascript
快速搭建vue2.0+boostrap项目的方法
2018/04/09 Javascript
Vue使用NPM方式搭建项目
2018/10/25 Javascript
JS实现的检验身份证格式并输出出生日期,年龄,性别,出生地示例
2019/05/17 Javascript
深入解析koa之中间件流程控制
2019/06/17 Javascript
微信小程序 搜索框组件代码实例
2019/09/06 Javascript
VSCode写vue项目一键生成.vue模版,修改定义其他模板的方法
2020/04/17 Javascript
使用Python判断IP地址合法性的方法实例
2014/03/13 Python
Python获取脚本所在目录的正确方法
2014/04/15 Python
Python日期时间对象转换为字符串的实例
2018/06/22 Python
利用python画出折线图
2018/07/26 Python
在python image 中安装中文字体的实现方法
2019/08/22 Python
详解python路径拼接os.path.join()函数的用法
2019/10/09 Python
工商管理专业职业生涯规划
2014/01/01 职场文书
运动会加油稿100字
2014/09/19 职场文书
土建施工员岗位职责
2015/04/11 职场文书
公司团队口号霸气押韵
2015/12/24 职场文书
Python 流媒体播放器的实现(基于VLC)
2021/04/28 Python
Pyqt5将多个类组合在一个界面显示的完整示例
2021/09/04 Python
世界十大狙击步枪排行榜
2022/03/20 杂记
MySQL表字段数量限制及行大小限制详情
2022/07/23 MySQL