2010-11-28 41 views
0

編輯:由於某種原因,它似乎是刷新提交按鈕時的頁面...任何想法?它是我的jQuery或PHP?

使用ajax和kohana php框架來處理這個簡單的聊天室腳本。我似乎無法讓我的腳本爲創建新用戶工作,但我在php和javascript中有非常糟糕的調試技巧。反正我不知道是否有什麼別的話來。這裏是我的代碼:

繼承人用戶類的代碼:

class Model_User extends Kohana_Model 
{ 
var $_loaded = false; 
var $session = false; 
var $username = false; 
var $loginkey = false; 

function __construct() 
{ 
    $this->session = Session::instance(); 
} 

function new_user($username) 
{ 
    if($this->username_exists($username)) 
    return false; 
    $this->username = $username; 
    $this->generate_key(); 
    return $this->update_db(); 
} 

function username_exists($username) 
{ 
    if(DB::select()->from('users')->where('username', '=', $username)->execute()->count()<1); 
    return false; 
    return true; 
} 

//helper methods 

private function generate_key() 
{ 
    if(! $username) 
    return false; 
    $this->loginkey = md5($username.((int)mt_srand()*1000)); 
    $this->session->set('loginkey',$this->loginkey); 
    return true; 
} 

private function update_db() 
{ 
    if(DB::insert('users', array('username'=>$this->username, 'loginkey'=>$this->loginkey))->execute()) 
    return true; 
    return false; 
} 
    } 

和繼承人的代碼來處理JSON請求:

public function action_new_user(){ 
    $user = new Model_User(); 
    $json['username_exists'] = "true"; 
    $username = $_POST['username']; 
    if(isset($username)) 
    { 
    if($user->username_exists($username)) 
    { 
    echo json_encode($json); 
    return; 
    } 
    $user->new_user($_POST['username']); 
    $json['username_exists'] = "false"; 
    } 
    $this->request->response = json_encode($json); 
} 

和繼承人的jQuery和HTML

<div id="chat_entry_errors"> 

</div> 

<form id="new_chat_entry" name="posttest"> 
    <input type="text" name="username" /> 
    <input type="submit" name="submit" value="New User" /> 
    </form> 

$(document).ready(function(){ 
$('#new_chat_entry').submit(function(){ 
    $.post('json/new_user', $('#new_chat_entry').serialize(), 
    function(data){ 
    if(data.username_exists=='true'){ 
    $('#chat_entry_errors').html('<div class=\"error\">Sorry that username is currently unavailable. Please choose another.</div>'); 
    } 
    else { 
    $('#chat_entry_errors').html('<div class=\"error\">Success!</div>'); 
    } 
    } 
); 
}); 
    }); 
+0

您是否在服務器日誌或瀏覽器中觀察到錯誤?也嘗試不用轉義''

Success!
''中的雙引號 – Philar 2010-11-28 18:47:32

+0

你使用Firebug嗎?它應該對你的調試有很大的幫助,在你的javascript中設置一個斷點並查看執行/返回的內容等等。 – 2010-11-28 18:47:47

回答

1

看起來像它的提交表單。由於您沒有操作參數,因此它會提交到同一頁面,就像刷新一樣。嘗試將return false;添加到提交函數的末尾。

$(document).ready(function(){ 
$('#new_chat_entry').submit(function(){ 
    $.post('json/new_user', $('#new_chat_entry').serialize(), 
    function(data){ 
    if(data.username_exists=='true'){ 
    $('#chat_entry_errors').html('<div class=\"error\">Sorry that username is currently unavailable. Please choose another.</div>'); 
    } 
    else { 
    $('#chat_entry_errors').html('<div class=\"error\">Success!</div>'); 
    } 
    } 
); 
return false; 
}); 
    }); 
相關問題