2012-04-06 15 views
6

通常のテキストフィールドで、ユーザーが文字列を入力します。 a)入力に何かがあるかどうか、b)入力に空白がないかどうか、c)が整数だけで、他の文字がないかどうかを調べます。 次に、送信ボタンをクリックします。 私はhtmlの動作を使用していないことに注意してください。入力には厳密なContent/Presentation/Behavior分離のonclickはありません。javascript focus()がフォーカスされていません

マイHTML:ので、すべての要素の最後に追加されたJavaScriptファイルの外部には(オンロード今気にせず)をロードできるようにしても

<form name="basicText" id="basicText" action=""> 
<p>Enter any ol' integer: 
<input type="text" id="inputBox" name="inputBox" size="14"/>  
<input value = "Next...?" type="submit" id="mySubmitBtn" name="mySubmitBtn"/> 
</p> 
</form> 
<script src="js/w1bscript.js" type="text/javascript"></script> 

注意。

はJavaScript:

var myButton1 = document.getElementById("mySubmitBtn"); 
var myForm1 = document.getElementById("basicText"); 
var myTextBox = myForm1.inputBox; 

function submitPress() { 
if(myTextBox.value.length == 0) { 
    alert("You didn't enter anything! Once more time, with feeling...") 
    basicText.focus(); 
    basicText.select(); 
} else if(/\s/.test(myTextBox.value)) { 
    alert("Eh... No spaces. Just integers. Try again..."); 
    basicText.focus(); 
    basicText.select(); 
    } else if (isNaN(myTextBox.value)==true) { 
    alert("Eh... Gonna need you to enter ONLY digits this time. kthnx."); 
    basicText.focus(); 
    basicText.select(); 
} else { 
    // The textbox isn't empty, and there's no spaces. Good. 
    alert("you've passed the test!") 
    } 
} 
myButton1.addEventListener('click', submitPress, false); 

私は間違った入力を入力すると、ロジックは動作しますが、カーソルは関係なく、私が使用しているブラウザ、バックテキストボックスに焦点を当てていないされていません。

フィドル:http://jsfiddle.net/2CNeG/

はあなたのフォーム要素に焦点を当てているようですが、私には見えます、 ドン

答えて

4

をいただき、ありがとうございます。あなたの代わりにあなたのテキストボックスに焦点を当てる必要があります:

document.getElementById('inputBox').focus(); 

myTextBox.focus()あなたのコードで。

+0

@DonGまた、検証の成否にかかわらず、フォームを送信しているようです。 – bfavaretto

+0

Yup;バリデーションが失敗したパスに対して、バリデーション関数でfalseを返すには、type = 'button' - OR--を使用する方が良いでしょう。 –

+0

さて、私はあなたの要点を見て、私はそれをmyTextBox.focus()に変更しました。入力/テキストボックスにはまだフォーカスがありません。 – DonG

6

アラートボックスにコメントを書き込むと、フォーカスが働いているのを見ることができます。しかし、解決策があります。これを試してください。うまくいくと思います。

setTimeout(function() { 
     document.getElementById('inputBox').focus(); 
    }, 0); 
+0

はい、私は、フォーカスが1秒間に分かれているのを見て、それから離れます。 – DonG