0

プロジェクタースクリーン用の簡単な周囲計算機を作ろうとしています。

コードは、ラジオ ボタン入力からの応答と対角線の長さを取得して、それに応じて周長を計算する必要があります。

ここに私のコードatmがあります:

<html>

    <body>
        <script language="javascript">
            function calc() {
                var form = document.forms.Calculator;
                var A = Number(getSelectedValue(form.elements.A));
                var B = Number(getSelectedValue(form.elements.B));


                if (A = 0) {
                    L = 0.8;
                    H = 0.6;
                } else if (A = 1) {
                    L = 0.872;
                    H = 0.49;
                } else {
                    L = 0.922;
                    H = 0.386;
                }

                form.elements.Total.value = 2 * B * (L + H);

            }

            function getSelectedValue(flds) {
                var i = 0;
                var len = flds.length;

                while (i < len) {
                    if (flds[i].checked) {
                        return flds[i].value;
                    }
                    i++;
                }

                return "";
            }
        </script>
        <title>Calculator</title>   <pre>
    <form name="Calculator">
        <label>A</label> 
            4:3: <input name="A" type="radio" onChange="calc()" value="0" checked>
            16:9: <input name="A" type="radio" onChange="calc()" value="1">
            2.39:1: <input name="A" type="radio" onChange="calc()" value="2">
        <label>B</label>
            Screen Size: <input name="B" type="text" onChange="calc()" checked>
        <label>Total</label> 
            <input type="text" name="Total" onChange="calc()" readonly size="10"><br> 
        <input type="submit" value="Submit Calculation"> <input type="reset" value="Clear"> 
    </form>
    </pre>

    </body>

</html>
4

1 に答える 1

0

あなたの機能getSelectedValueは間違っています。要素の配列をループして、どの要素がチェックされているかを確認します。同じことをしようとしているのは、B要素が 1 つだけであるため、ループを通過しないため、 が返されます''

だから代わりに

var B = Number(getSelectedValue(form.elements.B));

試す

var B = Number(form.elements.B.value);

また、 if else ステートメントが間違っています。==代わりに=次 のようにする必要があります。

if (A == 0) {
    L = 0.8;
    H = 0.6;
} else if (A == 1) {
    L = 0.872;
    H = 0.49;
} else {
    L = 0.922;
    H = 0.386;
}
于 2013-08-23T18:04:07.317 に答える