2014-01-27 76 views
1

我有一些jQuery,將根據另一個選擇框(它使用AJAX)的值更改選擇框的內容。 PHP正在返回我想要的數組(按TypeDescriptionData.name排序),但是列表在JS中某處被重新排序。有任何想法嗎?JSON重新排序返回列表

PHP電話:

public function get_descriptions_by_type($typeId) { 
    $this->autoRender = false; 

    $this->loadModel('TypeDescriptionData'); 

    $data = array(); 

    $this->TypeDescriptionData->contain(); 
    $descriptions = $this->TypeDescriptionData->find('list', array('conditions' => array('type_data_id' => $typeId), 'order' => 'name ASC')); 

    if(isset($descriptions) && is_array($descriptions)) { 
     foreach($descriptions as $x => $y) { 
      $data[$x] = $y; 
     } 
    } 

    echo json_encode($data); 
} 

這裏的json_encode PHP撥打以上後JSON權:

{ 
    "1":"FD 50", 
    "9":"Hypercom T4210", 
    "2":"Hypercom T7P", 
    "8":"Hypercom T7Plus", 
    "10":"Nurit 2085", 
    "11":"Nurit 8400", 
    "12":"Nurit 8400 Lite", 
    "17":"Other Terminal", 
    "13":"Verifone Tranz 330", 
    "14":"Verifone Tranz 380", 
    "15":"Verifone Vx510", 
    "16":"Verifone Vx510 LE" 
} 

這裏的JS:

$('#TypeType').change(function() { 
    $('#TypeDescription').find('option').remove().end(); 
    $.ajax({ 
     url:'/TypeData/get_descriptions_by_type/' + $(this).val(), 
     type:'POST', 
     dataType: 'json', 
     success: function(json) { 
      console.log(JSON.stringify(json)); 
      $.each(json, function(i, value) { 
       $('#TypeDescription').prepend($('<option>').text(value).attr('value', i)); 
      }); 
     } 
    }); 
}); 

而這裏的JSON如果我添加「的console.log(JSON.stringify(JSON));」以上:「功能(JSON){成功」,在JS:所述後立即

{ 
    "1":"FD 50", 
    "2":"Hypercom T7P", 
    "8":"Hypercom T7Plus", 
    "9":"Hypercom T4210", 
    "10":"Nurit 2085", 
    "11":"Nurit 8400", 
    "12":"Nurit 8400 Lite", 
    "13":"Verifone Tranz 330", 
    "14":"Verifone Tranz 380", 
    "15":"Verifone Vx510", 
    "16":"Verifone Vx510 LE", 
    "17":"Other Terminal" 
} 
+0

原始JSON的外觀如何? I.E.響應的內容。 –

回答

1

JSON對象是一個關聯數組,所以這兩個對象實際上等效。基本上計算機不記得順序,只是鍵/值對。如果訂單真的對你很重要,那麼你需要使用其他類型的結構。例如,您可以嵌入一個陣列:

{ 
    "beaches" : [ 
     {"key" : "1", "value" : "FD 50"}, 
     {"key" : "2", "value" : "Hypercom T7P"}, 
     {"key" : "8", "value" : "Hypercom T7Plus"} 
    ] 
}