JSON和PHP问题

时间:2011-09-01 17:10:33

标签: php jquery ajax json

我是JSON和AJAX的新手,因此在寻求解决方案并进行了几天的试验,然后再向这里询问。 我正在使用AJAX来处理提交的PHP页面。它正在保存信息,但我还需要PHP页面传递返回插入的ID。这是我到目前为止所拥有的。

成功:

success: function(){            
    $('#popup_name img').remove();
    $('#popup_name').html('Saved'); 
    $('#fade , .popup_block').delay(2000).fadeOut(function() {
        $('#fade, a.close').remove();  //fade them both out
        $.getJSON(pathName, function(json){
            alert('You are here');
            alert("Json ID: " + json.id);
        });
    });
}

然后,PHP脚本调用此方法插入信息并返回插入的id:

  public static function doInsertQuery($sparamQuery="",$bparamAutoIncrement=true,$sparamDb="",$sparamTable=""){
//do the insert
$iReturn = 0;
$result = DbUtil::doQuery($sparamQuery);
if(!$result){
  $iReturn = 0;
}
elseif(!$bparamAutoIncrement){
  $iReturn = DbUtil::getInsertedId();
}
else{
  $iReturn = DbUtil::getInsertedId();
}

//log the insert action
//if not a client logged in- cannot log to client db
if(Session::get_CurrentClientId() > 0){
  if($sparamTable != LogLogin::table_LOGLOGINS()){
    $oLog = new LogDbRequest();
    $oLog->set_Type(LogDbRequest::enumTypeInsert);
    $oLog->set_Request($sparamQuery);
    $oLog->set_RowId($iReturn);
    $oLog->set_TableName($sparamTable);
    $oLog->set_Before("NULL");
    $oLog->set_After(serialize(DbUtil::getRowCurrentValue($sparamDb,$sparamTable)));
    $oLog->insertorupdate_LogDbRequest();
  }
}
echo json_encode($iReturn);
return $iReturn;
}

我希望这是有道理的。我在这里完全失败了。任何帮助都将非常感谢! 〜麦克〜

1 个答案:

答案 0 :(得分:1)

真的很简单。 success函数接受与服务器响应对应的参数。

客户方:

$.ajax({
    'url':'/path/to/script.php',
    'dataType':'json',
    'success':function(response){ //note the response argument
        alert(response.id); //will alert the id
    }
});

服务器端:

<?php
    //...previous stuff here...
    $response = array('id' => $id); //where $id is the id to return to the client
    header('Content-type: application/json'); //Set the right content-type header
    echo json_encode($response); //Output array as JSON
?>