当前位置: 移动技术网 > IT编程>开发语言>JavaScript > js中的DOM模拟购物车功能

js中的DOM模拟购物车功能

2019年06月10日  | 移动技术网IT编程  | 我要评论
效果图: 代码如下: <!doctype html> <html> <head> <title>

效果图:

代码如下:

<!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>

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

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网