4

数字が押されたときに計算を実行する単純なフォームがありますが、これは数字が入力されたときにのみ発生し、文字が追加された場合に通知を表示したいと考えています。これを行う簡単な機能はありますか?

    <input onKeyPress="return onlyNumbers()" onKeyUp="calc()" id="value1" type="text" name="value1">
    <select onChange="calc()" id="manipulator" name="manipulator">
        <option value="commission">Commission</option>
        <option value="cost">Return</option>
    </select>
</form>

計算機能

function calc(){
    if (window.XMLHttpRequest){// code for IE7+, Firefox, Chrome, Opera, Safari
        xmlhttp=new XMLHttpRequest();
    } else {// code for IE6, IE5
        xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
    }

    val1 = document.getElementById("value1").value;
    mani = document.getElementById("manipulator").value;

    if (val1 != ""){
        document.getElementById("resp").innerHTML="Calculating...";
        queryPath = "comCalcServ.php?value1="+val1+"&manipulator="+mani;

        xmlhttp.onreadystatechange=function(){
            if (xmlhttp.readyState==4 && xmlhttp.status==200){
                document.getElementById("resp").innerHTML=xmlhttp.responseText;
            }
        }

        xmlhttp.open("GET",queryPath);
        xmlhttp.send();
    }
}

私は現在 isNaN 関数を見ていますが、JS 構文に慣れていないため、どこで使用すればよいかわかりません。

4

3 に答える 3

6

つまり:


//add inside your calc function
val1 = document.getElementById("value1").value;
if(/^\d+$/.test(val1)) {
 //proceed with rest of code
}
else {
 alert("Invalid");
 return false;
}

于 2012-04-30T09:04:06.613 に答える
-1

私の場合、上記のコードは機能しませんでした。だから私はいくつかの変更を加えました。正規表現をに変更した/^[0-9]*$/.test(val1)ところ、うまくいきました。

于 2016-04-11T06:46:08.157 に答える