Skip to main content

How not to lose focus on a login page


I have a simple login form with 2 input fields: "username" and "password". "username" field is focused by default. The problem is that when user clicks outside "username" or "password" fields, the focus is gone (it is neither on "username" nor on "password" fields"). How can I force the focus to be on these 2 fields only ?



In my case, this is a really annoying behavior, so I really want to do this :)



Can I do something like:




$("*").focus(function() {
if (!$(this).hasClass("my_inputs_class")) {
// How to stop the focusing process here ?
}
});



?


Source: Tips4allCCNA FINAL EXAM

Comments

  1. It sounds like you always want one of your inputs to be focused, fair enough. The way I would do this is to bind each of your inputs blur() events so that if it occurs, it goes to the next element.

    Here's the markup:

    <body>
    <form method="POST" action=".">
    <input type="text" name="username" />
    <input type="password" name="password" />
    <input type="submit" name="submit" />
    </form>
    </body>


    And here's the jQuery:

    $(document).ready(function() {
    // what are the named fields the user may focus on?
    var allowed = ['username', 'password', 'submit'];
    $.each(allowed, function(i, val) {
    var next = (i + 1) % allowed.length;
    $('input[name='+val+']').bind('blur', function(){
    $('input[name='+allowed[next]+']').focus();
    });
    });
    $('input[name='+allowed[0]+']').focus();
    });

    ReplyDelete
  2. You could use javascript to set the focus on focusout, but you really shoudn't. Forcing focus on those fields would break the normal interaction of the page. It would mean a user couldn't do something as simple as clicking on a link on the page, because focus would always be on those inputs.

    Please don't do it :)

    ReplyDelete
  3. If you really really want to do this (and you shouldn't) use delegate() instead of setting a separate event handler on every single HTML element:

    $('body').delegate('*', 'focus', function() {
    if (!$(this).hasClass("my_inputs_class")) {
    $('#username').focus();
    return false;
    }
    });


    But consider that this will make unacessible all elements except the two input fields via keyboard navigation (including the submit button, any links on the page etc.)

    ReplyDelete
  4. Set blur event handler so it brings back focus to one of your inputs.

    ReplyDelete
  5. You could do like this (in psuedo code):

    if user || pass blured
    if user.len > 0
    pass.setFocus
    else
    user.setFocus


    Hope you get it.

    ReplyDelete
  6. Install an onClick handler on the body element (or a div that covers most of the page). Clicking on the div should then set the focus on the username/password field.

    I also suggest to bind Return in the "username" to "Set focus on password" and Return in the "password" field to "Submit form".

    ReplyDelete
  7. You could enable the click on links by re-focusing on you inputs after a minimum time interval.

    Every time an object gains the focus you check if it has the required class: if not set the focus to the first of the form inputs; this way:

    <html>
    <head>
    <title>Example</title>
    <script type="text/javascript" src="http://code.jquery.com/jquery-1.4.2.min.js" />
    <script type="text/javascript" >
    $(function() {
    $('*').focus(function() { var obj = this; setTimeout(function () {checkFocus(obj)}, 1)});
    })

    function checkFocus(obj) {
    if (!$(obj).hasClass('force_focus')){
    $('input.force_focus:first').focus()
    }
    }
    </script>
    </head>
    <body>
    <a href="http://www.google.com">Extrnal link</a>
    <form><div>
    User: <input type="text" name="user" class="force_focus"/><br/>
    Password: <input type="password" name="password" class="force_focus"/><br/>
    Other: <input type="text" name="other" class=""/><br/>
    <input type="submit" name="submit" value="Login" />
    </div></form>
    </body>
    </html>

    ReplyDelete
  8. this is only an idea, you can use a setInterval function to put the focus in the username field, and you can interrupt it when you want with clearInterval function.

    var A = setInterval(function(){ $('#username').focus();}, 100);


    ... and for interrumpt it, you can do something like this

    $('#password').focus(function(){ clearInterval(A);});

    ReplyDelete

Post a Comment

Popular posts from this blog

Why is this Javascript much *slower* than its jQuery equivalent?

I have a HTML list of about 500 items and a "filter" box above it. I started by using jQuery to filter the list when I typed a letter (timing code added later): $('#filter').keyup( function() { var jqStart = (new Date).getTime(); var search = $(this).val().toLowerCase(); var $list = $('ul.ablist > li'); $list.each( function() { if ( $(this).text().toLowerCase().indexOf(search) === -1 ) $(this).hide(); else $(this).show(); } ); console.log('Time: ' + ((new Date).getTime() - jqStart)); } ); However, there was a couple of seconds delay after typing each letter (particularly the first letter). So I thought it may be slightly quicker if I used plain Javascript (I read recently that jQuery's each function is particularly slow). Here's my JS equivalent: document.getElementById('filter').addEventListener( 'keyup', function () { var jsStart = (new Date).getTime()...

Is it possible to have IF statement in an Echo statement in PHP

Thanks in advance. I did look at the other questions/answers that were similar and didn't find exactly what I was looking for. I'm trying to do this, am I on the right path? echo " <div id='tabs-".$match."'> <textarea id='".$match."' name='".$match."'>". if ($COLUMN_NAME === $match) { echo $FIELD_WITH_COLUMN_NAME; } else { } ."</textarea> <script type='text/javascript'> CKEDITOR.replace( '".$match."' ); </script> </div>"; I am getting the following error message in the browser: Parse error: syntax error, unexpected T_IF Please let me know if this is the right way to go about nesting an IF statement inside an echo. Thank you.