我试图了解我的错误在哪里,因为JS不可能在数学方面失败!
在HTML表单上,我有一个select和9文本输入.然后,在JS上我比较输入的文本.
我的问题如下:如果我写的话
new_da3 = 1400
new_a3 = 1900
Run Code Online (Sandbox Code Playgroud)
JS会说ok3.
如果我写信
new_da3 = 1900
new_a3 = 1400
Run Code Online (Sandbox Code Playgroud)
JS会说no3!
但如果我写的话
new_da3 = 1500
new_a3 = 800
Run Code Online (Sandbox Code Playgroud)
JS WILLL SAY ok3!
为什么?1500不大于800吗?
谢谢!
HTML:
<form>
<select id="new_nrp" onchange="selNrP(this.value);" style="background-color:#F00; color:#FFF">
<option value="" selected="selected"></option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
<?php
for($i=1; $i<=3; $i++){
print '<input type="text" size="5" maxlength="5" id="new_da'.$i.'">
<input type="text" size="5" maxlength="5" id="new_a'.$i.'">';
}
?>
<input type="submit" class="buttongreen" onClick="test()" value="Try the test function!">
</form>
Run Code Online (Sandbox Code Playgroud)
JS
function test(){
var new_da1 = document.getElementById('new_da1').value
var new_a1 = document.getElementById('new_a1').value
var new_da2 = document.getElementById('new_da2').value
var new_a2 = document.getElementById('new_a2').value
var new_da3 = document.getElementById('new_da3').value
var new_a3 = document.getElementById('new_a3').value
var new_nrp = document.getElementById('new_nrp').value
switch(new_nrp){
case '3':
if(new_a2 < new_da3 && new_da3 <= new_a3){
alert('ok3')
} else {
alert('no3')
return
}
case '2':
if(new_a1 < new_da2 && new_da2 <= new_a2){
alert('ok2')
} else {
alert('no2')
return
}
case '1':
if(new_da1 <= new_a1){
alert('ok1')
} else {
alert('no1')
return
}
break;
default:
alert("Why are you here?");
return;
}
}
Run Code Online (Sandbox Code Playgroud)
因为你要比较字符串,而不是整数.使用parseInt显式转换你的价值观为整数.
这基本上就是你在做什么:jsFiddle例子
要进行转换,请将变量更改为:
var new_da1 = parseInt( document.getElementById('new_da1').value, 10);
Run Code Online (Sandbox Code Playgroud)
(假设它们都是整数)
| 归档时间: |
|
| 查看次数: |
8381 次 |
| 最近记录: |