2016-04-02 11 views
1
<!DOCTYPE html> 
<html> 
<head> 
<script> 
function validateForm() { 
    var x = document.forms["myForm"]["fname"].value; 
    if (x == null || x == "") { 
     alert("Name must be filled out"); 
     return false; 
    } 
} 
</script> 
</head> 
<body> 

<form name="myForm" action="demo_form.asp" 
onsubmit="return validateForm()" method="post"> 
Name: <input type="text" name="fname"> 
<input type="submit" value="Submit"> 
</form> 

</body> 
</html> 

現在、検証でJavaScriptフォームを作成する方法を学習しています。ボタンを押すと、フォームはどこにでも送信されるわけではありません。バリデーションを含むJavaScriptフォームを作成し、送信したときに送信されるのはどうすればいいですか?

+0

ここでテストしたところ、私は 'demo_form.asp'にリダイレクトされました。そしてなぜ検証のために 'pattern'タグを使わないのでしょうか? – Filipe

+0

属性 'pattern'を意味します:) – GillesC

答えて

2

あなたはあなたがそれhereについての詳細を学ぶことができEvent.preventDefault()

を使用する必要があります。イベントフローの任意の段階でpreventDefaultを呼び出すと、イベントがキャンセルされます。つまり、イベントの結果として実装によって通常行われるデフォルトのアクションは発生しません。

jsfiddle here(2つの入力ボックス)を参照してください。 <br>は、各入力ボックスを改行して改行することに注意してください。

<script> 
function validateForm(e) { 
     e.preventDefault(); 
     var x = document.forms["myForm"]["fname"].value; 
     if (x == null || x == "") { 
      alert("Name must be filled out"); 
      return false; 
     } 
    } 
</script> 

<body> 
    <form name="myForm" action="demo_form.asp" 
     onsubmit="return validateForm(event)" method="post"> 
     Name: <input type="text" name="fname"><br> 
     New TextBox: <input type="text" name="textBox"><br> 
     <input type="submit" value="Submit"> 
    </form> 
</body> 
+0

これは完全に機能しました!フォームに2番目のセクションを追加して、同じボタンで記入して提出する方法を教えてもらえますか? – hithere

+0

どういう意味ですか?申し訳ありませんが、私はかなりフォローしていません。 –

+0

申し訳ありませんが、フォームに別のテキストボックスを追加するにはどうすればいいですか?おやすみなさい新品で – hithere

2

あなたはハンドリング機能でそれのためのパラメータを持っている場合、あなたが行うことができますので、のonclickイベントは、イベントオブジェクトを解析します:

function validateForm(evt) { 
//.preventDefault is a method of JavaScript events 
    evt.preventDefault(); 
} 

だから、基本的にあなたがsubmitボタンの前または後にロジックを追加することができますクライアント側の検証を行い、検証が失敗した場合はキャンセルし、ユーザがnumptyであることを怒らせます。

関連する問題