Обычное текстовое поле, пользователь вводит строку. Проверьте, а) есть ли что-то во входных данных, б) что во входных данных нет пробелов и в) только целые числа, никаких других символов. Затем кнопка отправки. Вы заметите, что я не использую поведение html, во входных данных нет щелчка, строгое разделение контента/презентации/поведения.
Мой HTML:
Также обратите внимание, что внешний файл javascript добавляется в конец, чтобы все элементы могли загружаться (не беспокойтесь о загрузке прямо сейчас).
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/
Спасибо, Дон