2011-08-09 10 views
3

私はclass="required"で各入力を通過するforループを持っていて、空であればその背景色が変わります。また、ページの一部にメッセージを追加します。「赤色の背景色のフィールドは必須です。しかし、私はそのメッセージを一度表示したいだけです。 5つのフィールドが空であっても、1つのメッセージしか表示されません。助言がありますか?部分を1回だけ実行しますか?

HERESに私のコード:

<script type="text/javascript" > 
window.onload = function() { 
document.getElementById("formID").onsubmit = function() { 
    var fields = this.getElementsByClassName("validate"), 
     sendForm = true; 
    for(var i = 0; i < fields.length; i++) { 
     if(!fields[i].value) { 
      fields[i].style.backgroundColor = "#ffb8b8"; 

    var inst = document.getElementById('inst'); 
     var reason = inst.insertRow(-1); 
     var cell1=reason.insertCell(0); 
     cell1.innerHTML = '<p>Fields with a red background are required and empty. Please fill them in and try resubmitting. Thanks.</p>'; 
     inst.appendChild(reason); 


    sendForm = false; 
     } 

    else { 
      fields[i].style.backgroundColor = "#fff"; 
     } 
} 
    if(!sendForm) { 
     return false; 
    } 
} 
} 
</script> 
+0

jQueryはオプションですか? – asawyer

+0

@Asawyerいいえ、申し訳ありません... –

答えて

2

これはむしろ単純です。すでに検証が失敗したかどうかを判断するブール変数を持っています - sendForm。だから、 "メッセージを追加する"部分をループの外に出てifに入れてください。

document.getElementById("formID").onsubmit = function() { 
    var fields = this.getElementsByClassName("validate"), 
     sendForm = true; 
    for(var i = 0; i < fields.length; i++) { 
     if(!fields[i].value) { 
      fields[i].style.backgroundColor = "#ffb8b8"; 

      sendForm = false; 
     } 

    else { 
      fields[i].style.backgroundColor = "#fff"; 
     } 
    } 
    if(!sendForm) { 
     var inst = document.getElementById('inst'); 
     var reason = inst.insertRow(-1); 
     var cell1=reason.insertCell(0); 
     cell1.innerHTML = '<p>Fields with a red background are required and empty. Please fill them in and try resubmitting. Thanks.</p>'; 
     inst.appendChild(reason); 
     return false;    
    } 
} 
+0

これを行うと、''の前に '' 'を指す' unterminated string literal 'と表示されます。 –

+0

@Jonah - Works for me:http://jsfiddle.net/QSXGC/ – Jamiec

3

あなたが真のフィールドが検証に失敗した任意の時間を設定します旗を持つことができます。ループが実行された後、フラグがtrueの場合は、エラーメッセージを追加します。

0

すでにメッセージ

window.onload = function() { 
    var notified = false; 

    for(var i = 0; i < fields.length; i++) { 
     if(!fields[i].value) { 
      fields[i].style.backgroundColor = "#ffb8b8"; 
      ... 
      if (!notified) { 
       cell1.innerHTML = '<p>Fields with a red background are required and empty. Please fill them in and try resubmitting. Thanks.</p>'; 
       inst.appendChild(reason); 
       notified = true; 
      } 
      .... 
} 
+0

これは 'var notified..'を参照して' missing variable name'というエラーを表示します。 –

1

がfalseに初期化し、uは任意の空のフィールドは、それが本当作る取得した場合にのみメッセージを印刷したら、フラグを使用して表示していることを示すためにブールフラグを追加flagはfalseです。ここに

<script type="text/javascript" > 
window.onload = function() { 
document.getElementById("formID").onsubmit = function() { 
    var fields = this.getElementsByClassName("validate"), 
     sendForm = true; 
    var flag=false; 
    for(var i = 0; i < fields.length; i++) { 
     if(!fields[i].value) { 
      fields[i].style.backgroundColor = "#ffb8b8"; 
    if(flag==false) { 
     var inst = document.getElementById('inst'); 
     var reason = inst.insertRow(-1); 
     var cell1=reason.insertCell(0); 
     cell1.innerHTML = '<p>Fields with a red background are required and empty. Please fill them in and try resubmitting. Thanks.</p>'; 
     inst.appendChild(reason); 
    } 
    flag=true; 


    sendForm = false; 
     } 

    else { 
      fields[i].style.backgroundColor = "#fff"; 
     } 
} 
    if(!sendForm) { 
     return false; 
    } 
} 
} 
</script> 
+0

うまく動作します!ありがとう.. –

関連する問題