Регулярное текстовое поле, пользователь вводит строку. Проверьте, есть ли в входе что-то), b) что во входных элементах нет пробелов, а в) - только целые числа, никаких других символов. Затем отправьте кнопку. Вы заметите, что я не использую поведение html, во входных данных не присутствует onclick, строгое разделение Content/Presentation/Behavior.javascript focus() не фокусируется
Мой HTML:
<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 файл добавляется в конце так что все элементы можно загружать (не заботясь о OnLoad прямо сейчас).
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);
Когда я ввожу неправильный вход, логика работает, но курсор не фокусируется обратно в текстовое поле, независимо от того, какой браузер я использую.
Fiddle: http://jsfiddle.net/2CNeG/
Спасибо, Дон
@DonG Вы также представляете форму независимо от прохождения проверки или нет. – bfavaretto
Yup; было бы лучше, если бы он использовал type = 'button' --OR-- для возврата false в функцию проверки для тех путей, где проверка не выполняется. –
Хорошо, я вижу вашу мысль, я изменил ее на myTextBox.focus(); и по-прежнему не фокусируется на ввод/текстовое поле. – DonG