依存リスト用の選択ボックスが 2 つあるフォームがあります。
複数選択である最初のリストで選択された値に基づいて、2 番目のリストをロードしています。
<select id="list1" multiple='multiple'>
<option value="a">a value</option>
<option value="b">b value</option>
<option value="c">c value</option>
</select>
<select id="list2">
</select>
list2 に追加されたオプションごとに、list2 の値に対応する list1 の値を持つクラスも追加しています。
選択したオプションの要素を読み込むには、次のコードを使用します。
$('#list1').on('change', function(){
var list1vals = $('#list1').val().split(',');
var newval = '';
for(x in list1vals)
{
// Checking for selected value of list1 which doesn't have
// corresponding values in list2.
if($('.'+list1vals[x]).length == 0)
{
newval = list1vals[x];
}
}
$.ajax({
type : "GET",
url : "/xyz.php?action=getlist2&list1="+newval,
success : function(response)
{
if($.trim(response) != '')
{
$('#list2').append(response);
}
}
});
});
xyz.php
$action=$_GET['action'];
$listval1=$_GET['list1'];
switch($action)
{
/////////////////
case 'getlist2':
$list2 = fetchlist2($list1val);
foreach($list2 as $listobj)
{
$optionlist = '<option class="'.$list1val.'" value="'.$listobj['id'].'">'.$listobj['value'].'</option>';
}
echo $optionlist;
break;
////////////////
}
list1 で選択されていない要素を list2 から削除する方法はありますか?
つまり、オプションが選択されていない場合、選択されていない要素のクラス値を持つ list2 内のすべての要素を削除したいと考えています。
注 : リストを取得する操作fetchlist2
はコストがかかるため、javascript で要素の削除を処理したいと考えています。