Таким образом, у меня есть 2 выпадающих списка, и результат будет сгенерирован для входного текста, но каким-то образом, если второй выпадающий список имеет 2 или более выбора, результат, который он генерирует, в конечном итоге будет получен из последнего выбора. Т.е. если первый выпадающий список имеет значения A и B, результат будет получен из B, и он не изменится, хотя я выберу A. Вот мой код HTML
<div class="form-group">
<label for="jurusan" class="control-label">Jurusan</label>
<select name="jurusan" id="jurusan" class="form-control">
<option selected disabled hidden>--PILIH--</option>
<?php
$query = $this->db->query('SELECT * FROM jurusan');
$jurusan = $query->result();
foreach($jurusan as $row) {
?>
<option value="<?php echo $row->id_jurusan ?>"><?php echo $row->nama_jurusan ?></option>
<?php } ?>
</select>
<span id="pilih"></span>
<span class="help-block"></span>
</div>
<div class="form-group" id="prodi">
<label for="nama_prodi" class="control-label">Prodi</label>
<select name="prodi" id="nama_prodi" class="form-control">
</select>
<span class="help-block"></span>
</div>
<div class="form-group">
<label for="add_kode" class="control-label">Kode Mata Kuliah</label>
<input type="text" name="kode_mata_kuliah" id="add_kode" class="form-control" placeholder="Masukkan Kode Mata Kuliah" required autocomplete="off">
<span class="help-block"></span>
</div>
, а вот мой jquery скрипт
$('#jurusan').change(function(){
var id = $(this).val();
if(id)
{
$.ajax({
url:'<?=base_url()?>administrator/mata_kuliah/get_data_jurusan',
method: 'post',
data: {id_jurusan: id},
dataType: 'json',
success: function(response){
$('#prodi').show();
console.log(response);
var output = [];
$.each(response,function(index,data)
{
output.push('<option value="'+data['id_prodi']+'">'+data['nama_prodi']+'</option>');
$('#nama_prodi').html(output.join(''));
var id = $('#nama_prodi').val();
if(id)
{
$.ajax({
url:'<?=base_url()?>administrator/mata_kuliah/get_data',
method: 'post',
data: {id_prodi: id},
dataType: 'json',
success: function(response){
$('#add_kode').empty();
$('#add_kode').val((data['kode_prodi']));
}
})
}
else
{
$('#add_kode').empty();
}
});
}
});
}
else
{
$('#jurusan').empty();
}
});
var id = $('#nama_prodi').val();
if(id)
{
$.ajax({
url:'<?=base_url()?>administrator/mata_kuliah/get_data',
method: 'post',
data: {id_prodi: id},
dataType: 'json',
success: function(response){
$('#add_kode').empty();
$('#add_kode').val((data['kode_prodi']));
}
})
}
else
{
$('#add_kode').empty();
}
контроллер
public function get_data()
{
$post = $this->input->post();
$data = $this->mata_kuliah->get_data($post);
echo json_encode($data);
}
public function get_data_jurusan()
{
$post = $this->input->post();
$data = $this->mata_kuliah->get_data_jurusan($post);
echo json_encode($data);
}
модель
public function get_data_jurusan($post)
{
$this->db->select('*');
$this->db->where('jurusan', $post['id_jurusan']);
$query = $this->db->get('prodi');
$response = $query->result_array();
return $response;
}
public function get_data($post)
{
$this->db->select('*');
$this->db->where('id_prodi', $post['id_prodi']);
$query = $this->db->get('prodi');
$response = $query->result_array();
return $response;
}