Ответ 1
Этот ответ содержит необходимые изменения для вашего кода.
ОТКАЗ ОТ ОТВЕТСТВЕННОСТИ. Не видя точной установки, имейте в виду, что может быть множество факторов, из-за которых это не работает "как есть" в вашей установке. Я не знаю, как настроены ваши маршруты, или если вы используете Firebug или какую-нибудь другую консоль для просмотра вызовов ajax, но это должно дать вам строительные блоки:
Во-первых, измените ваш php, чтобы вывести массив как строку, кодированную json:
public function getCars(){
$this->load->model('car_model');
$this->form_validation->set_rules('carId', 'carId', 'trim|xss_clean');
if($this->form_validation->run()){
$carId = $this->input->post('carId');
$carModels = $this->user_management_model->getCarModels($carId);
// Add below to output the json for your javascript to pick up.
echo json_encode($carModels);
// a die here helps ensure a clean ajax call
die();
} else {
echo "error";
}
}
Затем измените свой сценарий ajax-call, чтобы иметь обратный вызов успеха, который получает данные и добавляет его в раскрывающийся список:
function myFunction(obj)
{
$('#emptyDropdown').empty()
var dropDown = document.getElementById("carId");
var carId = dropDown.options[dropDown.selectedIndex].value;
$.ajax({
type: "POST",
url: "/project/main/getcars",
data: { 'carId': carId },
success: function(data){
// Parse the returned json data
var opts = $.parseJSON(data);
// Use jQuery each to iterate over the opts value
$.each(opts, function(i, d) {
// You will need to alter the below to get the right values from your json object. Guessing that d.id / d.modelName are columns in your carModels data
$('#emptyDropdown').append('<option value="' + d.ModelID + '">' + d.ModelName + '</option>');
});
}
});
}
Опять же - это строительные блоки. Используйте консоль браузера или инструмент, такой как Firebug, для просмотра запроса AJAX и возвращаемых данных, чтобы вы могли соответствующим образом изменить. Удачи!