2012-04-06 2 views
6

Регулярное текстовое поле, пользователь вводит строку. Проверьте, есть ли в входе что-то), 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/

Спасибо, Дон

ответ

4

Он смотрит на меня, как вы сосредоточены на форме элемента; Вы должны сосредоточиться на ваших текстовых полях вместо:

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

или myTextBox.focus() в вашем коде.

+0

@DonG Вы также представляете форму независимо от прохождения проверки или нет. – bfavaretto

+0

Yup; было бы лучше, если бы он использовал type = 'button' --OR-- для возврата false в функцию проверки для тех путей, где проверка не выполняется. –

+0

Хорошо, я вижу вашу мысль, я изменил ее на myTextBox.focus(); и по-прежнему не фокусируется на ввод/текстовое поле. – DonG

6

Вы заметите, что после того, как вы прокомментировали свое поле оповещения, вы сможете увидеть, как работает ваш фокус. Но есть решение для того же. Попробуйте это. Я думаю, это должно сработать.

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

Да, я вижу, что фокус там на долю секунды, затем уходит ... – DonG

Смежные вопросы