其實這個例子網上有很多,只是我在做的時候,出了一些問題,最後找到問題的解決辦法了,所以就想貼出來記錄下,引以為戒。
代碼如下:
<form name="add" method="post" action="test.php"> 使用者名稱:<input type="text" id="uname" name="username" /> </form>
$('#cname').blur(function(){ if($('#uname').val() == ''){ $('#result').html("<span style='color:red;'>不可為空</span>"); } else{ //var str = 'cname='+$('#cname').val(); $.get('test.php',{username:$('#uname').val()},function(data){ $('#result').html("<span style='color:red;'>"+data+"</span>"); }); } });
<?php mysql_connect('localhost','root',''); mysql_select_db('news'); mysql_query('set names utf8'); $a = $_GET['cname']; $sql = "select * from tnewscategory where cCategoryName = '$a'"; // $sql = "select count(*) from tnewscategory where cCategoryName = '$a'"; /* 問題就出在這個地方了,我原來用的是count(*)的查詢語句查詢的,但是驗證的結果都是可以註冊,不管是資料庫裡已存在的,還是未存在的資料,都提示可以註冊,後來換成 select * 就正常了。這兩種查詢方法,最終的查詢結果都是一個資源類型的。最終使用mysql_num_rows()轉化後,也確實得了一個數值,卻不知道為何返回到ajax驗證的時候,卻無法成功。當初使用count(*); 想著這種效率更快些,不想卻出了這樣的情況,暫時記錄下吧,以後找到原因,再做更新 */ $n = mysql_num_rows(mysql_query($sql)); if($n > 0){ echo "已存在"; exit; } else{ echo "可以註冊"; exit; } ?>