检查用户名是否存在 - 跨浏览器问题!建议?

Edz*_*son 0 html javascript php mysql ajax

我有一个注册表单,它动态地检查数据库中的现有用户名和电子邮件地址.但是,它似乎不适用于FireFox或IE.虽然它在Safari和Chrome上很棒.这是代码:

<input type="text" name="username" id="username" placeholder="Username" class="registerinvitel" onKeyUp="resettooltip();" onFocusOut="check_register_exist('username');" autocomplete="off" />
Run Code Online (Sandbox Code Playgroud)

和JavaScript:

function check_register_exist(meth){
    var cueajaxRequest;  // The variable that makes Ajax possible!

    try{
        // Opera 8.0+, Firefox, Safari
        cueajaxRequest = new XMLHttpRequest();
    } catch (e){
        // Internet Explorer Browsers
        try{
            cueajaxRequest = new ActiveXObject("Msxml2.XMLHTTP");
        } catch (e) {
            try{
                cueajaxRequest = new ActiveXObject("Microsoft.XMLHTTP");
            } catch (e){
                // Something went wrong
                alert("Your browser broke!");
                return false;
            }
        }
    }
    // Create a function that will receive data sent from the server
    cueajaxRequest.onreadystatechange = function(){
        if(cueajaxRequest.readyState == 4){
var cuerez = cueajaxRequest.responseText;

if ( cuerez == 'exist' ) { infotooltip(meth, cuerez); 

document.getElementById('chk'+meth).value = "exist";

} else { document.getElementById('chk'+meth).value = "ok"; }


        }
    }


    var curchk = document.getElementById(meth).value;
    var queryString = "meth="+meth+"&u=" + curchk;
    cuenocache = Math.random();
    cueajaxRequest.open("GET", "/ajax/check.php?" + queryString + "&nocache=" + cuenocache, true);
    cueajaxRequest.send(null); 


}
Run Code Online (Sandbox Code Playgroud)

有什么想法我可以改变它以使其工作?AJAX check.php代码如下(但我不认为这是问题):

<?

include  "../conf/config.php";

if(isset($_GET['meth'])) { $meth = $_GET['meth']; } else { $meth = ''; }
if(isset($_GET['u'])) { $u = $_GET['u']; } else { $u = ''; }


if ( $meth == 'username' ) {


$query_chkuser = mysql_query("SELECT * FROM members WHERE Username = '$u'");
$query_nr_res = mysql_num_rows($query_chkuser);

if ( $query_nr_res == '1' ) { echo "exist"; } else { echo "ok"; }


} 

elseif ( $meth == 'email' ) {


$query_chkuser = mysql_query("SELECT * FROM members WHERE Email = '$u'");
$query_nr_res = mysql_num_rows($query_chkuser);

if ( $query_nr_res == '1' ) { echo "exist"; } else { echo "ok"; }


} 

else {}
Run Code Online (Sandbox Code Playgroud)

Nie*_*sol 7

尝试onBlur而不是onFocusOut.

编辑:或者,甚至更好,onChange- 毕竟,如果用户没有更改文本,您不需要重新检查.

  • @imsiso`onChange`仅在字段失去焦点时才会触发,即使这样,只有在接收焦点后值发生变化时才会触发. (2认同)