【发布时间】:2014-04-13 21:17:47
【问题描述】:
我试图在价值达到零时显示支付的总利息的价值。所以基本上每个月的所有利息加在一起作为最终价值。然后我需要以百分比显示每月利息的值。我无法弄清楚这个公式。这是它的外观示例http://snag.gy/9vzGi.jpg
function buildResults() {
var amount = parseFloat(document.getElementById("loanAmt").value );
var monthly = parseInt(document.getElementById("monthlyPay").value );
var rate = parseFloat(document.getElementById("intRte").value );
rate = rate / 100 / 12;
var msg = "<table id='tablefont' border='3' width='65%'>";
msg += "<tr>";
msg += "<td>Month</td>";
msg += "<td>Principal Paid</td>";
msg += "<td>Interest Paid</td>";
msg += "<td>Loan Balance</td>";
msg += "</tr>";
newPrincipal=amount;
var m = 1; //months
while ( amount > 0 ) {
var interest = amount * rate;
var principal = monthly - interest;
if (principal > amount) {
principal = amount;
amount = 0.0;
} else {
amount -= principal;
}
var sum = (interest.toFixed(2) + m);
msg += "<tr><td align='left' bgcolor='pink'>"+m+"</td> \
<td align='left' bgcolor='pink'>$"+fixVal(principal,0,2,' ')+"</td> \
<td align='left' bgcolor='pink'>$"+fixVal(interest,0,2,' ')+"</td> \
<td align='left' bgcolor='pink'>$"+fixVal(amount,0,2,' ')+"</td></tr>";
m++;
}
var msg2 = "";
msg2 += "Loan Amount: $" + document.getElementById("loanAmt").value + "<br>";
msg2 += "Annual Interest: " + document.getElementById("intRte").value + "%" +"<br>";
msg2 += "Monthly Payment: $" + document.getElementById("monthlyPay").value + "<br>";
msg2 += "Monthly Interest: " + fixVal(interest,0,2,' ') +"<br>";
msg2 += "Months to pay off loan: " + (m-1) +"<br>";
msg2 += "Total Interest Paid: $" + sum + "<br>";
msg += "</table>";
document.getElementById("results").innerHTML = msg;
document.getElementById("overview").innerHTML = msg2;
}
【问题讨论】:
-
问题是什么?
-
查看示例链接。我似乎无法弄清楚显示支付总利息价值的公式。在左边写着“支付的总利息:43.71 美元”我想我必须找到一个将所有利息加在一起但似乎无法得到的公式。
-
我看不出问题出在哪里。 “支付的总利息”等于表中“支付的利息”列的总和。
-
这就是它的外观示例。我的版本只显示最终的兴趣值。
-
哦,我明白了。在您的循环中,只需将在另一个变量中计算的兴趣相加即可。
标签: javascript math formula