高分求解一个JS的问题,是关于商品总价的.

我想实现的效果是,商品数量变化,金额变化,然后总价变化。我自己已经写出了数量变化,金额变化的JS代码了,但是总价变化的地方出现了很多问题,所以你只需帮我解决总价的问题就行... 我想实现的效果是,商品数量变化,金额变化,然后总价变化。我自己已经写出了数量变化,金额变化的JS代码了,但是总价变化的地方出现了很多问题,所以你只需帮我解决总价的问题就行了。PS,这只是举例子,商品数量是不定的,价格也是多变的,那些写死的就不用啦。我之前用下面这个来实现,明显是写死了,假如商品数量增加一件,方法就失效了,所以这种方法肯定是不要的。oTotal.value=toSmallNumble(parseFloat(aMoney[0].innerHTML)+parseFloat(aMoney[1].innerHTML)+parseFloat(aMoney[2].innerHTML))//上面和下面的代码中oTotal是总价,aMoney是每件商品的金额(单价*数量)//下面是我的修改方法,但是出错了,为什么?for(i=0;i<aMoney.length;i++)//求总价{ aResult.push(parseFloat(aMoney[i].innerHTML)) sum+=aResult[i];}oTotal.value=sum问题就是,实现商品数量变化,金额变化,然后总价变化,怎么实现呢?还有一个问题在代码里面。记住要使用JS代码! 展开
 我来答
百度网友e5aca04
2016-07-21 · 超过43用户采纳过TA的回答
知道小有建树答主
回答量:137
采纳率:100%
帮助的人:70.5万
展开全部
<!DOCTYPE html>
<html>
<head>
<title> new document </title>
<meta charset="utf-8" />
<style>
#data{
width:800px;
border:1px solid #333;
border-collapse:collapse;
}
#data td,#data th{
border:1px solid #333;
text-align:center;
}
#data td[colspan="3"]{
text-align:right;
}
</style>
<script>
function calc(btn){
//1、向上一级找 td
var td = btn.parentNode;
//2、查找第二个子节点
var span = td.children[1];
//3、如果 btn.innerHTML == +
if(btn.innerHTML == "+"){
span.innerHTML = parseInt(span.innerHTML)+1;
}else{
if(span.innerHTML == "1"){
span.innerHTML="1";
}else{
span.innerHTML = parseInt(span.innerHTML)-1;
}
}

//计算小计
var tds = td.parentNode.getElementsByTagName("td");
//从tds[1]中,取出单价
var price = parseInt(tds[1].innerHTML);
console.log("单价:"+price);
var allPrice = price * parseInt(span.innerHTML);
console.log("小计:"+allPrice);
tds[3].innerHTML=allPrice;

//总计
var sum = 0;//用于累加 小计的和
var tbody = document.getElementsByTagName("tbody");
//获取tbody下所有的tr
var trs = tbody[0].children;
//循环遍历tr数组,获取每一个tr
for(var i=0;i<trs.length;i++){
//获取每一个 tr
var tr = trs[i];
//获取tr里面最后一个元素节点
var td = tr.lastElementChild;
sum = sum + parseInt(td.innerHTML);
}
//为 id=sum的td 赋值
document.getElementById("sum").innerHTML=sum;
}
</script>
</head>

<body>
<table id="data">
<thead>
<tr>
<th>商品名称</th>
<th>单价</th>
<th>数量</th>
<th>小计</th>
</tr>
</thead>
<tbody>
<tr>
<td>iphone6</td>
<td>4488</td>
<td>
<button onclick="calc(this)">-</button>
<span>1</span>
<button onclick="calc(this)">+</button>
</td>
<td>4488</td>
</tr>
<tr>
<td>iphone6 plus</td>
<td>5288</td>
<td>
<button onclick="calc(this)">-</button>
<span>1</span>
<button onclick="calc(this)">+</button>
</td>
<td>5288</td>
</tr>
<tr>
<td>iphone6s</td>
<td>5288</td>
<td>
<button onclick="calc(this)">-</button>
<span>1</span>
<button onclick="calc(this)">+</button>
</td>
<td>5288</td>
</tr>
<tr>
<td>iphone6s plus</td>
<td>6088</td>
<td>
<button onclick="calc(this)">-</button>
<span>1</span>
<button onclick="calc(this)">+</button>
</td>
<td>6088</td>
</tr>
</tbody>
<tfoot>
<tr>
<td colspan="3">总计</td>
<td id="sum">0</td>
</tr>
</tfoot>
</table>
</body>
</html>

直接上代码 我用table做的 你看下!!!
更多追问追答
追问
试了试,确实实现了。我想问你一个类似的问题,我试了一天了,都解决不了。由于代码太长了,我上传去百度云给你看吧。因为你这个还没解决我的一个疑问
追答
没收到通知
网易云信
2023-12-06 广告
很高兴能回答您的问题。以下是一段针对“一对一消息组件”的描述,字数在200字左右:该组件支持用户之间的私密交流,让沟通更加直接和高效。通过它,您可以向特定对象发送消息,并实时查看消息状态,包括对方是否已读或未读。同时,该组件还支持富文本消息... 点击进入详情页
本回答由网易云信提供
纯洁的小树
2016-07-21 · TA获得超过3386个赞
知道大有可为答主
回答量:2536
采纳率:71%
帮助的人:476万
展开全部
看不出来问题,控制台看看具体报什么错呗
追问
没报错,只是实现的东西不理想。
追答
额。。。能多贴一点你计算的代码上来么?如果你实现的单个商品的总价变动,那所有总价应该就一样呀!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式