-2

HTML の私のコードは、ユーザー入力の数値を受け取り、計算を行ってから出力を表示します。ユーザーが選択した入力が数式に入れられ、数式の結果がユーザー入力の数値に加算されますが、2 つの数値を加算すると小数点が追加されます。

たとえば、数値 11 が選択された場合、Rchange の結果は 0.22 になるため、.22 に 11 が追加されて newResistance の 11.22 になりますが、代わりに値が 110.22 として表示されます。

function calc(form) {
    if (isNaN(form.resistance.value)) {
        alert("Error in input");
        return false;
    }
    if (form.resistance.value.length > 32) {
        alert("Error in input");
        return false;
    }
    var Rchange = .01 * 2 * form.resistance.value;
    var newResistance = (form.resistance.value + Rchange);
    document.getElementById("newResistance").innerHTML = chopTo4(newResistance);
}

function chopTo4(raw) {
    strRaw = raw.toString();
    if (strRaw.length - strRaw.indexOf("0") > 4) strRaw = strRaw.substring(0, strRaw.indexOf("0") + 5);
    return strRaw;
}
4

3 に答える 3

0

試してみてくださいnewResistance = +form.resistance.value + Rchange;。これで数値に変換されます。

于 2012-07-19T16:51:59.957 に答える
0

HTML DOM 要素のプロパティは常に文字列です。使用法では、それらを数値に変換する必要があります。

parseInt(form.resistance.value);
parseFloat(form.resistance.value);
+form.resistance.value;

(3 つのうちどれでも動作します。私は最初の 2 つを好みます (float を探している場合を除き、parseInt を使用します)。)

于 2012-07-19T16:53:06.040 に答える
0

これは、値を文字列として扱っているためです。

form. resistance. value + Rchange は両方とも文字列なので、それを追加しています。

parseInt JavaScript メソッドを使用して、10 進数バージョンを取得します。

于 2012-07-19T16:54:11.670 に答える