0

我正在开发一种用户必须插入用户名的表单。我想检查模糊用户的用户名是否有效:

我添加了这个脚本:

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.0/jquery.min.js"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.9/jquery-ui.min.js"></script>

在 HTML 中:

<input name="username" type="text" onblur="checkUsername()">

脚本:

function checkUsername(){
    var usn = document.getElementsByName('username')[0];
    if(usn.value != "") {
       var html = $.ajax({
       type: "GET",
       url: "checkUsername.php?",
       data: "usr=" +usr.value 
       async: false,
       dataType: "text"}).responseText;   
       if(html == "si") {
          usn.style.backgroundColor = "green";
       } else {
          usn.style.backgroundColor = "red";
          usn.value = "Username still exists!";
       }
    }
}

所以onBlur不起作用,当我提交表单时出现如下错误:

HTTP Error 405.0 - Method Not Allowed
The page you are looking for cannot be displayed because an invalid method (HTTP verb) is being used.

我能做些什么?哪里有问题?

4

4 回答 4

2

首先考虑将您的 JQuery 升级到 1.6.x 版本。

试试这个修改后的脚本版本:

function checkUsername(){
    var usn = document.getElementsByName('username')[0];
    if(usn.value != "") {
       var html = $.ajax({
       url: "checkUsername.php",
       data: "usr=" +usr.value 
       async: false,
       dataType: "text"}).responseText;   
       if(html == "si") {
          usn.style.backgroundColor = "green";
       } else {
          usn.style.backgroundColor = "red";
          usn.value = "Username still exists!";
       }
    }
}
于 2012-01-31T23:14:01.157 回答
1

通常当我从 Jquery 运行 AJAX 命令时,我的数据属性是这样的数组:

 $.ajax({
    type: "GET",
    url: "checkUsername.php",
    data: {
        usr: usr.value 
    },
   async: false,
   dataType: "text"}).responseText;   
于 2012-01-31T23:10:44.307 回答
0

在选项中添加

dataType: 'jsonp',
于 2012-11-11T04:32:45.687 回答
0

另一件事是检查 ajax 调用上方的 javascript 错误,这也会导致 405 错误...

于 2013-11-05T01:32:39.307 回答