- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我知道我还没有设置验证,但我不明白为什么我在 2/5 结果字段中得到 NaN。任何帮助将不胜感激!
产生 NaN 的字段是 interestPay 和 gainLoss。我知道 gainLoss 与 interestPay 相关,所以如果我能解决这个问题,它可能会同时解决两个问题。
我尝试在计算后对 monthlyBalance 使用 parseFloat 和 parseInt,但这不起作用。
有什么建议吗?
<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Bankrate Payment Calculator Test | Todd Adel</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<!-- Bootstrap -->
<link href="css/bootstrap.min.css" rel="stylesheet" media="screen">
<link href="css/bootstrap-responsive.min.css" rel="stylesheet" media="screen">
<link href="css/style.css" rel="stylesheet" media="screen">
<script type="text/javascript">
function calculateThis(form) {
//Get a reference to the form id="calculator"
var theForm = document.forms["calculator"];
var balance = parseFloat(document.getElementById('balance').value);
var charge = parseFloat(document.getElementById('charge').value);
var spending1 = parseFloat(document.getElementById('spending1').value);
var spending2 = parseFloat(document.getElementById('spending2').value);
var spending3 = parseFloat(document.getElementById('spending3').value);
var cashBack1 = (parseFloat(document.getElementById('cashBack1').value)) / 100;
var cashBack2 = (parseFloat(document.getElementById('cashBack2').value)) / 100;
var cashBack3 = (parseFloat(document.getElementById('cashBack3').value)) / 100;
var everythingElse = parseFloat(document.getElementById('everythingElse').value);
var cashBackEE = (parseFloat(document.getElementById('cashBackEE').value)) / 100;
var payOff = parseFloat(document.getElementById('payOff').value);
var interestRate = (parseFloat(document.getElementById('interestRate').value)) / 100;
// Calculate monthlyBalance
var monthlyBalance = document.getElementById('monthlyBalance');
monthlyBalance.innerHTML = "$" + (balance + charge - payOff);
// Calculate interestPay
var interestPay = document.getElementById('interestPay');
interestPay.innerHTML = "$" + monthlyBalance * interestRate / 12;
// Calculate cashBackEarned
var cashBackEarned = document.getElementById('cashBackEarned');
cashBackEarned.innerHTML = "$" + ((spending1 * cashBack1) + (spending2 * cashBack2) + (spending3 * cashBack3) + (everythingElse * cashBackEE));
// Calculate gainLoss
var gainLoss = document.getElementById('gainLoss');
gainLoss.innerHTML = "$" + (cashBackEarned - interestPay);
// Calculate earnedRewards
var divobj = document.getElementById('earnedRewards');
if (cashBackEarned >= 0) {
var earnedRewards = true;
divobj.innerHTML = "Yes";
} else {
earnedRewards = false;
divobj.innerHTML = "No";
}
}
</script>
</head>
<body>
<form id="calculator" class="form-inline">
<div id="container">
<div id="inner" class="row">
<div class="row header"><h1>Are you paying for cash-back rewards?</h1></div>
<div class="row subhead"><h2>Fill out the form below to find out now</h2></div>
<div class="row data">
<div class="span10 question">What was your balance left over from last month?:</div>
<div class="span2 input"><span>$</span><input class="input-mini" name="balance" id="balance" type="text" /></div>
</div>
<div class="row data">
<div class="span10 question">How much did you charge this month?</div>
<div class="span2 input"><span>$</span><input class="input-mini" name="charge" id="charge" type="text" /></div>
</div>
<div class="row data">
<div class="span10 question">Choose a spending category
<select name="spending_category" size="1" class="input-med">
<option value="1">Spending Category 1</option>
<option value="2">Spending Category 2</option>
<option value="3">Spending Category 3</option>
</select>
</div>
<div class="span2 input"><span>$</span><input class="input-mini" name="spending1" id="spending1" type="text" /></div>
</div>
<div class="row data">
<div class="span10 question">What was your % Cash Back?</div>
<div class="span2 input"><span>%</span><input class="input-mini" name="cashBack1" id="cashBack1" type="text" /></div>
</div>
<div class="row data">
<div class="span10 question">Choose a spending category
<select name="spending_category" size="1" class="input-med">
<option value="1">Spending Category 1</option>
<option value="2">Spending Category 2</option>
<option value="3">Spending Category 3</option>
</select>
</div>
<div class="span2 input"><span>$</span><input class="input-mini" name="spending2" id="spending2" type="text" /></div>
</div>
<div class="row data">
<div class="span10 question">What was your % Cash Back?</div>
<div class="span2 input"><span>%</span><input class="input-mini" name="cashBack2" id="cashBack2" type="text" /></div>
</div>
<div class="row data">
<div class="span10 question">Choose a spending category
<select name="spending_category" size="1" class="input-med">
<option value="1">Spending Category 1</option>
<option value="2">Spending Category 2</option>
<option value="3">Spending Category 3</option>
</select>
</div>
<div class="span2 input"><span>$</span><input class="input-mini" name="spending3" id="spending3" type="text" /></div>
</div>
<div class="row data">
<div class="span10 question">What was your % Cash Back?</div>
<div class="span2 input"><span>%</span><input class="input-mini" name="cashBack3" id="cashBack3" type="text" /></div>
</div>
<div class="row data span12"><a href="#" class="btn btn-primary" style="float:right">Add Category</a></div>
<div class="row data">
<div class="span10 question">What did you spend on everything else?</div>
<div class="span2 input"><span>$</span><input class="input-mini" name="everythingElse" id="everythingElse" type="text" /></div>
</div>
<div class="row data">
<div class="span10 question">What was your % Cash Back?</div>
<div class="span2 input"><span>%</span><input class="input-mini" name="cashBackEE" id="cashBackEE" type="text" /></div>
</div>
<div class="row data">
<div class="span10 question">How much did you pay off?</div>
<div class="span2 input"><span>$</span><input class="input-mini" name="payOff" id="payOff" type="text" /></div>
</div>
<div class="row data">
<div class="span10 question">Interest rate on credit card</div>
<div class="span2 input"><span>%</span><input class="input-mini" name="interestRate" id="interestRate" type="text" /></div>
</div>
<div class="row data span12"><a href="#" class="btn btn-primary" style="float:right" onclick="calculateThis()">Calculate</a></div>
<div class="row span12"><h2>Results</h2></div>
<div id="results">
<div class="row data blue">
<div class="span10 question">Monthly Balance</div>
<div id="monthlyBalance" class="span2 input"><span>$</span></div>
</div>
<div class="row data white">
<div class="span10 question">How much will you pay in interest?</div>
<div id="interestPay" class="span2 input"></div>
</div>
<div class="row data blue">
<div class="span10 question">Cash back earned this month</div>
<div id="cashBackEarned" class="span2 input"></div>
</div>
<div class="row data white">
<div class="span10 question">How much $ did you gain / lose?</div>
<div id="gainLoss" class="span2 input"></div>
</div>
<div class="row data blue">
<div class="span10 question">Did you pay for your rewards?</div>
<div id="earnedRewards" class="span2 input"></div>
</div>
</div> <!-- End #results -->
</div> <!-- End #inner -->
</div> <!-- End #container -->
</form>
<script src="http://code.jquery.com/jquery.js"></script>
<script src="js/bootstrap.min.js"></script>
</html>
最佳答案
在你的代码中你有:
var monthlyBalance = document.getElementById('monthlyBalance');
这将检索 ID 为“monthlyBalance”的 DOM 元素。
稍后你有:
interestPay.innerHTML = "$" + monthlyBalance * interestRate / 12;
这意味着您正在尝试将 DOM 元素(不是数字)与 interestRate/12 相乘。
尝试将您的代码更改为以下内容:
// Calculate monthlyBalance
var monthlyBalance = balance + charge - payOff;
var monthlyBalanceDomObject = document.getElementById('monthlyBalance');
monthlyBalanceDomObject.innerHTML = "$" + monthlyBalance;
关于javascript - 当所有变量和输入都是数字时,为什么我会得到 NaN?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17449796/
首先我想说的是,我知道isNaN()和 Number.isNaN()工作。我正在阅读 David Flanagan 的 The Definite Guide,他举例说明了如何检查值是否为 NaN :
在表中,对于 skips day 列,最后一行的默认值始终是单词“last”,它不是数字。现在,结果日期显示为“NaN/NaN/NaN”,有什么方法可以将其替换为 Nil 之类的东西。 非常感谢。
我正在制作一个网站,如果用户登录,则会为用户提供一定的注销时间,其中定义了注销时间,剩余时间是从注销时间 - 服务器时间获得的。 我已经通过 PHP 获得了注销时间和服务器时间,但我想动态显示剩余时间
我有以下代码,它简单地初始化一个 UIImageView 以适应 UIImage 在当前屏幕尺寸上尽可能大的比例: CGSize mainScreenSize = [appDelegate mainS
这个问题已经有答案了: Why in numpy `nan == nan` is False while nan in [nan] is True? (1 个回答) 已关闭 3 年前。 我只是觉得这有
我有动态 JQGrid,其中一列是日期列。我从包含 URL 和日期的 feed 中获取数据。 我需要为“日期列”开发列模型,使其显示日期和超链接。但不幸的是,数据显示为 NAN/NAN/NAN (这可
我已经包含了一个演示我的问题的片段。基本上处理给了我这个错误: 调用map(NaN, -3, 3, -125, 125),返回NaN(不是数字) 我理解此消息的方式是,map 函数返回 NaN,并且由
我在下面创建的过滤器适用于 Chrome,但不适用于 Firefox。我不明白为什么。 myApp.filter('dateCustom', [ '$filter', function ($fil
虽然问题的第一部分(在标题中)之前已经回答过几次(即 Why is NaN not equal to NaN? ),但我不明白为什么第二部分会以它的方式工作(受此启发问题 How to Check l
我需要在数组中找到min和max值(不考虑可能的NaN值在这个数组中)。 这只使用 double 会很容易,但是这些 FindMin 和 FindMax 函数必须使用泛型类型。 我尝试以这种方式测
我正在开发一个屏幕,其中 UIScrollView 内只有一个 UIImageView。 UIScrollView 使用户能够固定和缩放图像。我从下面的帖子中得到了帮助。它使用 Storyboard和
尽管看到了类似的答案,但我不知道这里发生了什么。我制作了一个自定义的 UIImageview,它应该在创建后立即开始动画: class HeaderAnimator: UIImageView {
我正在寻找一个 pandas 系列并用下一个数值的平均值填充 NaN,其中:average = next numerical value/(# consecutive NaNs + 1) 到目前为止,
我有一个 mySql 表,其中有一个名为 posts 的列,该列设置为 timestamp 类型,默认为 current_timestamp。然后,我使用 php PDO 获取它的值(以及其他一些列)
我想知道以下类型的 nan 之间有什么区别。除了 NAN_macro (计算结果为 -nan(ind) 而不是 nan )的视觉差异外,它们的行为似乎都相同(根据下面的示例脚本)。 我看了一些其他的答
我为我的网页做了倒计时;它在除 Mozilla 和 IE 之外的所有浏览器上都能正常工作。 我做错了什么,我该如何解决? 下面是我的代码: ***var dt = '2018-06-14 11:59
在将 Xcode 更新到 8.3 后,我在启动时开始收到此错误:由于未捕获的异常“CALayerInvalidGeometry”而终止应用程序,原因:“CALayer 位置包含 NaN:[nan na
我正在使用 jquery 自动完成 onselect 它在不同的文本字段中显示数据。我使用 format_date() 函数在 #dob 和 #anniversery 中显示格式化日期 select:
我有一个带有 json Store 和 DateField 的网格。 Firefox 运行良好,但在 Internet Explorer 8 中无法运行。 我这样定义: function conver
我有一个错误,它在启动时使应用程序崩溃。这是我得到的错误: *** Terminating app due to uncaught exception 'CALayerInvalidGeometry'
我是一名优秀的程序员,十分优秀!