全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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>

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


# js购物车功能  # js  # 模拟购物车  # js实现购物车的功能  # js购物车实现思路及代码(个人感觉不错)  # Javascript操纵Cookie实现购物车程序  # 简单的前端js+ajax 购物车框架(入门篇)  # js实现简单的购物车有图有代码  # 原生js模拟淘宝购物车项目实战  # JavaScript编写一个简易购物车功能  # 基于Vuejs实现购物车功能  # 利用Angularjs和bootstrap实现购物车功能  # js+cookies实现悬浮购物车的方法  # 小计  # 遍历  # 加载  # td  # body  # border  # width  # solid  # px  # collapse  # thead  # onclick  # button  # span  # btnClick  # tbody  # tr  # id  # class  # pre 


相关文章: ,在苏州找工作,上哪个网站比较好?  如何高效配置IIS服务器搭建网站?  如何用花生壳三步快速搭建专属网站?  C#怎么使用委托和事件 C# delegate与event编程方法  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  建站之星图片链接生成指南:自助建站与智能设计教程  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  如何高效搭建专业期货交易平台网站?  如何配置支付宝与微信支付功能?  微网站制作教程,我微信里的网站怎么才能复制到浏览器里?  Swift中switch语句区间和元组模式匹配  如何通过远程VPS快速搭建个人网站?  建站之星免费版是否永久可用?  如何通过网站建站时间优化SEO与用户体验?  ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?  如何撰写建站申请书?关键要点有哪些?  建站之星CMS建站配置指南:模板选择与SEO优化技巧  如何用景安虚拟主机手机版绑定域名建站?  高端云建站费用究竟需要多少预算?  教程网站设计制作软件,怎么创建自己的一个网站?  PHP 500报错的快速解决方法  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  建站OpenVZ教程与优化策略:配置指南与性能提升  建站之星后台管理系统如何操作?  无锡营销型网站制作公司,无锡网选车牌流程?  再谈Python中的字符串与字符编码(推荐)  ,网页ppt怎么弄成自己的ppt?  清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?  一键网站制作软件,义乌购一件代发流程?  制作企业网站建设方案,怎样建设一个公司网站?  MySQL查询结果复制到新表的方法(更新、插入)  建站之星如何快速解决建站难题?  中山网站推广排名,中山信息港登录入口?  小型网站制作HTML,*游戏网站怎么搭建?  建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析  如何在云服务器上快速搭建个人网站?  建站之星如何通过成品分离优化网站效率?  网站制作公司,橙子建站是合法的吗?  C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  如何配置FTP站点权限与安全设置?  制作网站公司那家好,网络公司是做什么的?  宝塔新建站点报错如何解决?  建站之星代理平台如何选择最佳方案?  如何挑选优质建站一级代理提升网站排名?  建站之星如何取消后台验证码生成?  上海网站制作开发公司,上海买房比较好的网站有哪些?  c++ stringstream用法详解_c++字符串与数字转换利器 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。