2012-06-12 50 views
0

我有一個PHP函數返回JSON響應ajax請求的傳送費用。這裏是PHP函數:PHP和Prototype的AJAX

public function getDeliveryOptions($weight, $postcode) 
{ 

    if($weight == 0) 
    { 

     return array(array("name" => "Non-Deliverable", "value" => "0.00")); 

    } 

    $this->db->where('dmc_lower_boundary <=', $weight); 
    $this->db->where('dmc_upper_boundary >=', $weight); 

    if(preg_match("([aA][bB](3[1-8]|4[1-5]|5[1-6])\s?[1-9][a-zA-Z]{2}|[fF][kK](19|20|21)\s?[1-9][a-zA-Z]{2}|[hH][sS][1-9]\s?[1-9][a-zA-Z]{2}|[iI][vV][1-9]{1,2}\s?[1-9][a-zA-Z]{2}|[kK][aA](27|28)\s?[1-9][a-zA-Z]{2}|[kK][wW][1-9]{1,2}?\s?[1-9][a-zA-Z]{2}|[pP][aA][2-8][0-9]\s?[1-9][a-zA-Z]{2}|[pP][hH]([156789]|1[056789]|[2-5][0-9]){1,2}\s?[1-9][a-zA-Z]{2}|[zZ][eE][1-9]\s?[1-9][a-zA-Z]{2})", $postcode)) 
    { 

     $this->db->where("dm_id = ", 1); 
     $this->db->or_where("dm_id =", 3); 

    } 
    elseif(preg_match("/([bB][tT][1-9]{1,2}\s?[1-9][a-zA-Z]{2}|[iI][mM][1-9]{1,2}\s?[1-9][a-zA-Z]{2}|[tT][rR](21|22|23|24|25)\s?[1-9][a-zA-Z]{2})/", $postcode)) 
    { 

     $this->db->where("dm_id =", 1); 
     $this->db->or_where("dm_id =", 4); 

    } 
    elseif(preg_match("/([gG][yY][1-9]\s?[1-9][a-zA-Z]{2}|[jJ][eE][1-4]\s?[1-9][a-zA-Z]{2})/", $postcode)) 
    { 

     $this->db->where("dm_id =", 1); 
     $this->db->or_where("dm_id =", 5); 

    } 
    else 
    { 

     $this->db->where("dm_id =", 1); 
     $this->db->or_where("dm_id =", 2); 

    } 

    $this->db->group_by("dm_id"); 
    $query = $this->db->get("delivery_method_option_views"); 
    //print_r($query->result()); 
    //print_r(json_encode($query->result())); 
    return(json_encode($query->result())); 
} 

這裏是我的JavaScript(使用原型)將結果發送到服務器,並使用響應創建單選按鈕:

function updateDelivery() 
{ 
if($('deliveryUpdate') == null) 
{ 

    return false; 

} 

// This 'observes' our form submit - sort of like onsubmit 
$('deliveryUpdate').observe('submit', function(evt) { 

    // Stop the actual event from happening 
    evt.stop(); 

    // This is the url we submit to - change it as needed 
    var url = '/checkout/updateDelivery'; 

    //This will be the form and div we update 
    var containerForm = $('deliveryUpdate'); 
    var optionsDisplay = $('deliveryOptions'); 

    // Grab all the info in the form 
    var form_data = containerForm.serialize(); 
    var form = containerForm.innerHTML; 

    // Here we make the request 
    new Ajax.Request(url, { 
     method: 'post', 
     parameters: form_data, 
     onCreate: function() { 
      form = containerForm.innerHTML; 
      containerForm.update(form+'<img src="/images/loader.gif" alt="loading..." class="loader" />'); 
     }, 
     onSuccess: function(transport) { 
      containerForm.update(form); 
      NVPResponse = transport.responseText; 

      if(NVPResponse !== '[object Array]') 
      { 

       NVPResponse = new Array(NVPResponse); 

      } 
      alert(NVPResponse); 
      options = ""; 
      for(i=0; i<NVPResponse.length; ++i) 

      { 

       options += '<label for="delivery">'+NVPResponse[i].dm_name+'</label><input type="radio" name="delivery" value="'+NVPResponse[i].dmc_price+'" />'; 

      } 

      //optionsDisplay.update(NVPResponse); 
      optionsDisplay.update(options); 
     } 

    }); 

}); 

} 

如果我剛剛與更新JSON結果(郵編ab31 2AS),我得到如下:

Calculate Delivery Costs[{"dm_id":"1","dm_name":"Royal Mail","dm_admin_name":"Royal Mail","dmc_lower_boundary":"101","dmc_upper_boundary":"250","dmc_price":"3.65"},{"dm_id":"3","dm_name":"Courier","dm_admin_name":"Fed Ex Zone 4","dmc_lower_boundary":"101","dmc_upper_boundary":"250","dmc_price":"4.50"}]

但是,如果我的選項VAR更新,我得到 「未定義」,其中標籤文本和單選按鈕值。這是在onSuccess函數的for循環中構建的。有任何想法嗎?

編輯

我之前添加以下代碼在for循環,因爲我試圖用JSON字符串作爲對象,而不是對象:

NVPResponse = JSON.parse(NVPResponse); 

回答

1

我沒有什麼大的專家原型,但在我看來,你的NVPResponse是一個字符串,沒有翻譯成JavaScript對象。 (請參閱AJAX(具體評估JavaScript響應)和JSON的原型文檔)。

此外,您的代碼似乎還有一些其他問題。

在PHP代碼:

if($weight == 0) 
    { 

     return array(array("name" => "Non-Deliverable", "value" => "0.00")); 

    } 

你不JSONing它返回一個數組,是故意的嗎?

此外,還有似乎是一個邏輯錯誤:

$this->db->or_where("dm_id =", 3); 

查詢的dm_id = 3無論任何以前的「在那裏」您設置,使

$this->db->where('dmc_lower_boundary <=', $weight); 
$this->db->where('dmc_upper_boundary >=', $weight); 

將被忽略如果dm_id = 3(或當然任何其他or_where)。 該解決方案可以是這樣的:

$this->db->where_in("dm_id", array(1,3)); 

編輯:

在這種情況下,你所寫的作品非常清楚的查詢,但你應該注意到,笨並沒有把周圍的括號或參數在其查詢,因此在同一個查詢中結合OR和AND可能會有問題。 的方式,你寫的代碼查詢會是這個樣子(這工作正常):

SELECT * FROM (`t_name`) 
WHERE `dmc_lower_boundary` <= $weight AND `dm_id` = 1 OR `dm_id` = 3 

編寫相同的查詢在不同的順序(或有時編寫複雜查詢時)可以給你一個非常不同的結果:

SELECT * FROM (`t_name`) 
WHERE `dm_id` = 1 OR `dm_id` = 3 AND `dmc_lower_boundary` <= $weight 

經過幾次嚴重的bug,我學會了小心「or_where」 :)

+0

但我的數據庫查詢拉正確的結果? :S感謝第一個數組雖然:) –

+0

我的不好。 CI沒有在OR語句中放置括號,因此它們往往是越野車。我編輯了答案來反映這一點。 – Elad