1 番目の選択で行った選択に基づいて 2 番目の選択を設定する方法がわかりません。私がやりたいことは、場所を追加することです。場所を追加するには、大陸、国、地域、都市のselect
4 つの最初のものを用意します。options
そして、たとえばselect
都市タイプの場合、2 番目の選択で、都市を接続できる地域のみを表示したいと考えています。国を選択した場合、2 番目の選択で大陸のみを表示する必要があります。
これまでのところ、私はこれを持っています:
<p><label for="type_id">Tip de locatie:</label><br />
<select class="styled" name="type_id" id="type_id">
<option value="0">Alege...</option>
<?php
foreach ($place_type as $key => $type) { ?>
<option value="<?=$type['id']?>"><?=$type['name']?></option>
<?php } ?>
</select>
</p>
<noscript>
<input type="submit" name="action" value="Load Parents" />
</noscript>
<p><label for="parent_id">Leaga de:</label> <br />
<select class="styled" name="parent_id" id="parent_id">
<option value="0">Alege...</option>
<?php
foreach ($places as $key => $place) { ?>
<option value="<?=$place['id']?>"><?=$place['name']?></option>
<?php } ?>
</select>
</p>
私は codeigniter フレームワークを使用しており、コントローラーにこのメソッドがあります:
public function get_place_parent()
{
$this->load->model('places_model');
$places = $this->places_model->get_places();
$places = json_encode($places);
return $places;
}
そしてjQuery
<script type="text/javascript" charset="utf-8">
$(function(){
$("select#type_id").change(function(){
$.getJSON("<?=site_url('admin/get_place_parent')?>",{type_id: $(this).val(), ajax: 'true'}, function(j){
var options = '';
for (var i = 0; i < j.length; i++) {
options += '<option value="' + i + '">' + j[i] + '</option>';
}
$("select#parent_id").html(options);
})
})
})
</script>
これを行う方法がよくわかりません。このチュートリアルに基づいています: http://remysharp.com/2007/01/20/auto-populating-select-boxes-using-jquery-ajax/
前もって感謝します!