Js代码实现商品价钱总和(模拟购物车功能)

2024-01-11 11:30

本文主要是介绍Js代码实现商品价钱总和(模拟购物车功能),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

用js简单实现商品数量的选购、小计的计算以及总的价钱数、总的商品数量等一系列操作。代码如下:

题设的主体HTML代码如下:(以作事例)

<body>
<ul id="list"><li>樱桃<br><input type="button" value="-" /><strong>0</strong><input type="button" value="+" />单价:<em>12.5元</em>小计:<span>0元</span></li><li>香蕉<br><input type="button" value="-" /><strong>0</strong><input type="button" value="+" />单价:<em>2.5元</em>小计:<span>0元</span></li><li>火龙果<br><input type="button" value="-" /><strong>0</strong><input type="button" value="+" />单价:<em>8.5元</em>小计:<span>0元</span></li><li>榴莲<br><input type="button" value="-" /><strong>0</strong><input type="button" value="+" />单价:<em>28元</em>小计:<span>0元</span></li><li>车厘子<br><input type="button" value="-" /><strong>0</strong><input type="button" value="+" />单价:<em>14.5元</em>小计:<span>0元</span></li><li>菠萝<br><input type="button" value="-" /><strong>0</strong><input type="button" value="+" />单价:<em>7元</em>小计:<span>0元</span></li>
</ul>
<p>
商品合计共:<em>0件</em>,共花费了:<em>0元</em><br />
其中最贵的商品单价是:<strong>0元</strong>
</p>
</body>
  • 《原生版》JavaScript代码如下:
<script>
window.onload = function(){var  oP = document.getElementsByTagName('p')[0];var  aEm = oP.getElementsByTagName('em');var  aStrong = oP.getElementsByTagName('strong')[0];var  oUl = document.getElementById('list');var  oLi = oUl.getElementsByTagName('li');var  oStrong = oUl.getElementsByTagName('strong');var  oSpan = oUl.getElementsByTagName('span');var  oEm = oUl.getElementsByTagName('em');var sum = 0;var emMax = 0;for(var i=0;i<oEm.length;i++){//最大的那个单价值if(parseFloat(oEm[i].innerHTML)>emMax){emMax=parseFloat(oEm[i].innerHTML);}aStrong.innerHTML=emMax+'元';}//调用fn1()函数实现商品数量的选取for(var i=0;i<oLi.length;i++){fn1(oLi[i]);}//添加点击事件获取总的商品数量aEm[0].onclick = function(){for(var i=0;i<oStrong.length;i++){var a = Number(oStrong[i].innerHTML);sum+=a;aEm[0].innerHTML = sum+'件';}sum= 0;}//添加点击事件获取总的价钱aEm[1].onclick = function(){for(var i=0;i<oSpan.length;i++){var a = parseFloat(oSpan[i].innerHTML);sum+=a;aEm[1].innerHTML = sum+'元';}sum= 0;}function fn1(aLi){var oBtn = aLi.getElementsByTagName('input');var	oStrong = aLi.getElementsByTagName('strong')[0];var	oEm = aLi.getElementsByTagName('em')[0];var	oSpan = aLi.getElementsByTagName('span')[0];var n1 = Number(oStrong.innerHTML);var n2 = parseFloat(oEm.innerHTML);oBtn[0].onclick = function(){n1--;if(n1<0){n1 = 0;}oStrong.innerHTML = n1;oSpan.innerHTML = n1*n2+'元';};oBtn[1].onclick = function(){n1++;oStrong.innerHTML = n1;oSpan.innerHTML = n1*n2+'元';};}
}
</script>


反思:上述代码添加点击事件获取商品的总价钱数以及总的商品数量,可能增加了用户负担。需要改进

  • 《改进版》JavaScript代码如下:
window.onload = function(){var oP = document.getElementsByTagName('p')[0];var	aEm = oP.getElementsByTagName('em');var	aStrong = oP.getElementsByTagName('strong')[0];var oUl = document.getElementById('list');var oLi = oUl.getElementsByTagName('li');var oStrong = oUl.getElementsByTagName('strong');for(var i=0;i<oLi.length;i++){fn1(oLi[i]);}function fn1(aLi){var oBtn = aLi.getElementsByTagName('input');var	oStrong = aLi.getElementsByTagName('strong')[0];var	oEm = aLi.getElementsByTagName('em')[0];var	oSpan = aLi.getElementsByTagName('span')[0];var n1 = Number(oStrong.innerHTML);var n2 = parseFloat(oEm.innerHTML);//合计总价,必然要相加所有的小计function fn2(){var sum1=0;//定义一个临时变量,用来储存所加过的件数var sum2=0;//定义一个临时变量,用来储存所加过的小计var emMax=0;//定义一个临时变量,用来比较单价的大小for(var i=0;i<oLi.length;i++){var strongs=oLi[i].getElementsByTagName("strong")[0];//获取到所有li的数量var spans=oLi[i].getElementsByTagName("span")[0];//获取到所有li的小计var em=oLi[i].getElementsByTagName("em")[0];//获取到所有li的单价sum1=sum1+Number(strongs.innerHTML);sum2=sum2+parseFloat(spans.innerHTML);//合计即所有小计相加的结果,因为有小数所以要用parseFloatif(parseFloat(em.innerHTML)>emMax){//最大的那个单价值emMax=parseFloat(em.innerHTML);}}aEm[0].innerHTML=sum1+'件';aEm[1].innerHTML=sum2+'元';aStrong.innerHTML=emMax+'元';}fn2();oBtn[0].onclick = function(){n1--;if(n1<0){n1 = 0;}oStrong.innerHTML = n1;oSpan.innerHTML = n1*n2+'元';fn2();//调用合计之后的值};oBtn[1].onclick = function(){n1++;oStrong.innerHTML = n1;oSpan.innerHTML = n1*n2+'元';fn2();};}
}
</script>
此时总的商品件数和商品总计会随用户的商品选择进行实时改变。

这篇关于Js代码实现商品价钱总和(模拟购物车功能)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/594215

相关文章

Golang实现基于角色的访问控制(RBAC)的项目实践

《Golang实现基于角色的访问控制(RBAC)的项目实践》基于角色的访问控制(RBAC)是一种安全机制,通过角色来管理用户权限,本文介绍了一种可落地、易扩展的GolangRBAC实现方案,具有一定... 目录一、RBAC 核心模型设计二、RBAC 核心逻辑实现RBAC 管理器定义基础 CRUD:添加用户

Python使用Spire.PDF实现为PDF添加水印

《Python使用Spire.PDF实现为PDF添加水印》在现代数字化办公环境中,PDF已成为一种广泛使用的文件格式,尤其是在需要保持文档格式时,下面我们就来看看如何使用Python为PDF文件添加水... 目录一、准备工作二、实现步骤1. 导入必要的库2. 创建 PdfDocument 对象3. 设置水印

python在word中插入目录和更新目录实现方式

《python在word中插入目录和更新目录实现方式》文章主要介绍了如何在Word文档中插入和更新目录,并提供了具体的代码示例,插入目录时,需要使用`TablesOfContents`对象,并设置使用... 目录1、插入目录2、更新目录总结1、插入目录需要用到对象:TablesOfContents目录的

PostgreSQ数据库实现在Windows上异地自动备份指南的详细教程

《PostgreSQ数据库实现在Windows上异地自动备份指南的详细教程》这篇文章主要为大家详细介绍了如何在Windows系统上实现PostgreSQL数据库的异地自动备份,文中的示例代码讲解详细,... 目录前期准备实现步骤步骤一:创建备份脚本步骤二:配置免密登录(可选但推荐)步骤三:设置任务计划程序步

利用c++判断水仙花数并输出示例代码

《利用c++判断水仙花数并输出示例代码》水仙花数是指一个三位数,其各位数字的立方和恰好等于该数本身,:本文主要介绍利用c++判断水仙花数并输出的相关资料,文中通过代码介绍的非常详细,需要的朋友可以... 以下是使用C++实现的相同逻辑代码:#include <IOStream>#include <vec

基于C++的UDP网络通信系统设计与实现详解

《基于C++的UDP网络通信系统设计与实现详解》在网络编程领域,UDP作为一种无连接的传输层协议,以其高效、低延迟的特性在实时性要求高的应用场景中占据重要地位,下面我们就来看看如何从零开始构建一个完整... 目录前言一、UDP服务器UdpServer.hpp1.1 基本框架设计1.2 初始化函数Init详解

Java中Map的五种遍历方式实现与对比

《Java中Map的五种遍历方式实现与对比》其实Map遍历藏着多种玩法,有的优雅简洁,有的性能拉满,今天咱们盘一盘这些进阶偏基础的遍历方式,告别重复又臃肿的代码,感兴趣的小伙伴可以了解下... 目录一、先搞懂:Map遍历的核心目标二、几种遍历方式的对比1. 传统EntrySet遍历(最通用)2. Lambd

springboot+redis实现订单过期(超时取消)功能的方法详解

《springboot+redis实现订单过期(超时取消)功能的方法详解》在SpringBoot中使用Redis实现订单过期(超时取消)功能,有多种成熟方案,本文为大家整理了几个详细方法,文中的示例代... 目录一、Redis键过期回调方案(推荐)1. 配置Redis监听器2. 监听键过期事件3. Redi

SpringBoot全局异常拦截与自定义错误页面实现过程解读

《SpringBoot全局异常拦截与自定义错误页面实现过程解读》本文介绍了SpringBoot中全局异常拦截与自定义错误页面的实现方法,包括异常的分类、SpringBoot默认异常处理机制、全局异常拦... 目录一、引言二、Spring Boot异常处理基础2.1 异常的分类2.2 Spring Boot默

基于SpringBoot实现分布式锁的三种方法

《基于SpringBoot实现分布式锁的三种方法》这篇文章主要为大家详细介绍了基于SpringBoot实现分布式锁的三种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、基于Redis原生命令实现分布式锁1. 基础版Redis分布式锁2. 可重入锁实现二、使用Redisso