I have the following function in JavaScript every part of the if statement executes properly except giving focus back to the element which called the function.  It does not work in IE or Fire Fox, and neither browser gives me an error.  It looks correct to me... Why isn't it working?
function check(x){
     //doing some stuff
     if (uc_check == false){
          window.alert('Houston, we have a 开发者_StackOverflowproblem.');
          document.getElementById(x).value = '';
          document.getElementById(x).focus(); //this line is not working 
     }
}
P.S. I am calling this function from a form input like this:
onchange="check(this.id)"
The problem here is that when the onChange function finishes, it sets focus to the next element. So, any focus you set in that function will only go away after the onChange ends.
You can get around this a number of ways. Probably the easiest is to use a timeout.
Change your focus line to the following:
var el = document.getElementById(x);
window.setTimeout(function(){el.focus();}, 100);
You already have a reference to the element (this) so you don't need to pass an id around:
<input onchange="check(this);">
And the JS:
function check(el) {
    if (uc_check == false) {
        el.value = '';
        el.focus();
    }
}
 
         
                                         
                                         
                                         
                                        ![Interactive visualization of a graph in python [closed]](https://www.devze.com/res/2023/04-10/09/92d32fe8c0d22fb96bd6f6e8b7d1f457.gif) 
                                         
                                         
                                         
                                         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论