2017-04-20 7 views
0

VATを処理するためのコードを再作成しましたが、空の値だけでなく、3,000,000未満の値についても検証する必要があります。 Javascriptは本当に私の強みではないので、私はむしろ基本的なようなことをするのに苦労しています。これまで私はこれを持っています:フォームのバリデーション

<script language="javascript"> 

    // starts calculation 
    function calculate() { 
     var vat, total, vatTotal, finalTotal; 

     var frm = document.calculator; 

     total = evalnum(frm.total.value); 
     if (total == "NaN") 
      total = 0; 
     if (total == 0) { 
      alert("Please enter a valid ammount first."); 
      frm.total.focus() 
      return 
     } 
     else 
      frm.total.value = evalpound(total); 
     { 
      vatTotal = total * 0.005; 
      frm.calcvat.value = evalpound(vatTotal); 
      frm.calctotal.value = evalpound(total + vatTotal); 
     } 
    } 

    //---------------------------------------------------------------------------- 
    // Scripts for VAT calculator 
    //---------------------------------------------------------------------------- 

    var frm = document.calculator; 

    // ---------------------------------------------------------------------------- 
    function selectBox(frmE, selectText) { 

     var i; 
     var selectIndex = 0; 

     for (var i = 0; i < document.calculator[frmE].length; i++) { 
      if (document.calculator[frmE].options[i].value == selectText) { 
       selectIndex = i; 
      } 
     } 

     return selectIndex; 
    } 

    // ---------------------------------------------------------------------------- 
    function evalnum(numstr) { 

     var i, c, neg; 
     var ret = ""; 
     var p = false; 

     neg = 1; 
     if (numstr.indexOf("-") >= 0) { 
      neg = -1; 
     } 

     for (i = numstr.length - 1; i >= 0; i--) { 
      c = numstr.charAt(i); 

      if (c == ".") { 
       if (p == false) 
        p = true; 
       else 
        c = ""; 
      } 

      if ((c < "0" || c > "9") && c != ".") 
       c = ""; 

      ret = c + ret; 
     } 

     if (ret == "" || ret == "NaN") 
      ret = "0"; 
     return parseFloat(ret * neg); 

    } 

    // ---------------------------------------------------------------------------- 
    function evalpound(num) { 

     var i, l, d; 
     var nums; 
     var ret; 

     nums = String(Math.round(num * 100)); 

     while (nums.length < 3) 
      nums = "0" + nums; 

     l = nums.length - 3; 
     ret = "." + nums.charAt(l + 1) + nums.charAt(l + 2); 

     d = 0; 
     for (i = l; i >= 0; i--) { 
      ret = nums.charAt(i) + ret; 
      d++; 
      if (d == 3 && i > 0) { 
       ret = "," + ret; 
       d = 0; 
      } 
     } 

     ret = "£" + ret; 
     return ret; 

    } 

</script> 

HTMLコードは以下の通りです。

<form name="calculator"> 
<td class="calcbody" width="220" valign="top">Salary Bill:</td> 
<td class="calcbody" width="150"><input type="text" class="calcinput" name="total" title 
min="0" max format value size="9" style="width: 100px; text-align: right;" 
onchange="calculate(this)"></td> 
<tr> 
<td width="100" height="22" class="calcbody" align="center"><a class="calcbutton" 
href="javascript:calculate(this)">Calculate</a></td> 
<tr> 
<td colspan="2" class="calcsubtitle"><b>Results</b></td> 
<td></td> 
</tr> 
<tr> 
<td class="calcbody" valign="top">result</td> 
<td class="calcbody"><input type="text" class="calcinput" name="calcvat"></td> 
<td class="calcbody"></td> 
</tr> 
+0

IDは –

+0

を識別するためにもhtmlフォームコードを追加してください、申し訳ありませんが、フルフォームで編集 –

+0

常に関連コードの[mcve]で投稿してください。余りにも無駄ですが、余りにも圧倒的です。 – evolutionxbox

答えて

0

固定しました。 HTMLは関係なく動作します(古いコードです)。私は

 total = evalnum(frm.total.value); 
    if (total == "NaN") 
     total = 0; 
    if (total == 0) { 

は私が総==に< 3000000とかをしようとし、代わりに==を置き換えるまま

 total = evalnum(frm.total.value); 
    if (total == "NaN") 
     total = 0; 
    if (total < 3000000) { 

をなったの.jsの変更でただ無能でした。私は非常に基本的な変更を言ったように - どんな場合でも助けてくれてありがとう:)

関連する問題