使用if计算基于年龄的点数.Else语句中,脚本只显示第一个值



我想有人在JavaScript的经验,请通过这个脚本,并告诉我我做错了什么,这个脚本的应用程序可以在jsfiddle看到。第一个脚本showAge()应该从Date of Birth获取年龄,然后用结果填充txt字段"age"。然后,第二个脚本应该解析"age"字段并检查结果是否匹配任何标准(在if..else语句中显示),然后根据if..else语句填充两个字段(rsltf和rsltq)。但是现在它只输出10和16(两个if…else if语句的第一个值),而不考虑年龄。我实在想不明白:/

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Quebec and Federal Immigration Points Calculator</title>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3/jquery.min.js"></script>
<script type="text/javascript"> 
function showAge(){ 
var d =document.getElementById('dob').value.split('/'); 
var today = new Date(); 
var bday = new Date(d[2],d[1],d[0]);
var age = today.getFullYear() - bday.getFullYear();  
if(today.getMonth() < bday.getMonth() || (today.getMonth() == bday.getMonth() && today.getDate() < bday.getDate()))  
{
     t = age--;  
}
else {
t = age
}
form.age.value = t; 
} 
</script> 
<script type="text/javascript">
function compute(form)
{
var a = parseInt(form.age.value, 10) || 0; 
if (21 <= a <= 49){
    f = 10;
}
else if (20 == a == 50){
    f = 8;
}
else if (19 == a == 51){
    f = 6;
}
else if (18 == a == 52){
    f = 4;
}
else if (17 == a == 53){
    f = 2;
}
else if (17 > a > 53){
    f = 0;
}
form.rsltf.value = f;
if (18 <= a <= 35){
    q = 16;
}
else if (a == 36){
    q = 14;
}
else if (a == 37){
    q = 12;
}
else if (a == 38){
    q = 10;
}
else if (a == 39){
    q = 8;
}
else if (a == 40){
    q = 6;
}
else if (a == 41){
    q = 4;
}
else if (a == 42){
    q = 2;
}
else if (18 > a > 43){
    q = 0;
}
form.rsltq.value = q;   
}
</script>
</head>
<body>
<form name="form">
<p>Your Date of Birth (format:<strong>dd/mm/yyyy</strong>)</p><br />
<input onBlur="compute(this.form)" onchange="showAge()" name="dob" id="dob" />
<p>Your Age</p><input name="age" type="text" style="font-size: 15px" value="" size="7" readonly>
<h1>Your education</h1>
<INPUT NAME="calc" VALUE="Calculate" TYPE="button" onClick="compute(this.form)"><br />
<input name="rsltf" type="text" style="font-size: 50px" value="" size="20" readonly /><br />
<input name="rsltq" type="text" style="font-size: 50px" value="" size="20" readonly />
</form>
</body>
</html>

你不能在javascript: 21 <= a <= 49

你必须做21 <= a && a <= 49

21 <= a <= 49被解释为(21 <= a) <= 49,因此它将bool值与49进行比较。当转换为数字时,bool将变为1或0,因此它将始终小于49。

这段代码根本不起作用:

function compute(form)
{
var a = parseInt(form.age.value, 10) || 0; 
if (21 <= a <= 49){
    f = 10;
}
else if (20 == a == 50){
    f = 8;
}
else if (19 == a == 51){
    f = 6;
}
else if (18 == a == 52){
    f = 4;
}
else if (17 == a == 53){
    f = 2;
}
else if (17 > a > 53){
    f = 0;
}

JavaScript会这样解释:

21 <= a <= 49
(21 <= a) <= 49
(1 or 0) <= 49
true

你需要冗长:

(21 <= a) && (a <= 49)

下面的代码呢:

17 == a == 53

它应该做什么?

最新更新