-1

我有这个 ajax 函数:

function getpage(page,div){
var url = page+"&sid="+Math.random();
    var xhr; 
    try {  xhr = new ActiveXObject('Msxml2.XMLHTTP');   
    }
    catch (e) 
    {
        try {   xhr = new ActiveXObject('Microsoft.XMLHTTP');    
        }
        catch (e2) 
        {
          try {  xhr = new XMLHttpRequest();     
          }
          catch (e3) {  
          xhr = false;   
          }
        }
     }

    xhr.onreadystatechange  = function()
    { 
         if(xhr.readyState  == 4){
              if(xhr.status  == 200)
                document.getElementById(div).style.display= "block";
                document.getElementById(div).innerHTML = xhr.responseText; 
         }else{
                document.getElementById(div).innerHTML = '<img src="./pic/load.gif" />';
         }
    }; 

   xhr.open( "GET", url,  true); 
   xhr.send(null); 
}

我有 singup 表格(使用 smarty 模板设计):

<div><input style="width:300px" class="inp" type="text" onkeyup="getpage('./ajax.php?action=regnewuser&usern={$uname}','register')" name="User_name"  placeholder="username" required /></div><div class="hr" id="register"></div>

我有这个 ajax.php 代码:

if($act == 'regnewuser'){
            $usern   = protect($_GET['usern']);

        $sql = $db->query("SELECT USER_NAME FROM ".$pre."USERS");
            while($row = $db->record()){
            $dbuname = strtolower($row['USER_NAME']);
            $uname2  = strtolower($usern);
            }
        if(empty($usern)){
            echo '<div class="rd">please fill the box !!</div>';
        }elseif(strlen($usern) < 4){
            echo '<div class="rd">too short !!</div>';
        }elseif(strlen($usern) > 50){
            echo '<div class="rd">too tall !!</div>';
        }elseif($dbuname == $uname2){
            echo '<div class="rd">not available !!</div>';
        }
    }

但结果总是“请填写”;
我认为模板形式的问题!
我应该做什么但进入模板以获得正确的结果?

4

1 回答 1

0

您的代码{$uname}打算做什么?onkeyup

对我来说看起来像 PHP 代码。

您需要使用 JavaScript 将用户名附加到 URL。如果要在代码元素上设置id属性以生成 URL,则为:inputid

var url = "/ajax.php?action=regnewuser&usern=" + document.getElementById("username").value();

我建议在单独的函数中执行此操作并将生成的 URL 传递给您的getpage函数。

也就是说,我不确定onkeyup将您的代码附加到的正确事件。您真的想在每次在文本框中按下一个键时创建一个用户记录吗?

例如,如果用户键入“测试”,您是否希望创建 4 条记录?('t','te','tes','test')

我建议在用户完成填充文本框并且满意后添加一个按钮供用户单击(将您的代码附加到onclick按钮的事件中)。

于 2013-01-30T15:59:00.043 回答