我有一个动态生成的选择标签。基本上,每次生成表行时,select标记也会生成。这一切都是通过PHP和html完成的:
<?php $a=0; ?>
<?php foreach($routes as $r){?>
<tr>
<td><?php echo $r['ROUTE']; ?></td>
<td><?php echo $r['CARRIER']; ?></td>
<td>
<select id="driver_list<?php echo $a ?>" onChange="removeDriver()">
<option value=''>Select</option>
<?php foreach ($driver as $d){?>
<option value="<?echo trim($d['DRIVER_NUMBER']);?>"
<?php echo ($driver == $d['DRIVER_NUMBER']) ? "selected" : ''?>>
<?php echo trim($d['DRIVER_NUMBER']) . ' - ' . $d['FIRST_NAME'] . ' ' . $d['LAST_NAME']?>
</option>
<?php } ?>
</select>
</td>
<td class="right"><?php foreach ($route['action'] as $a) { ?>
[ <a href="<?php echo $a['href']; ?>"><?php echo $a['text']; ?></a> ]
<?php } ?>
</td>
</tr>
<?php } ?>
说我明天有6条路线,我有12个司机可供选择。我想创建一个从下一个动态生成的列表中删除从当前列表中选择的值的函数。最初,每个列表将有12个驱动程序。当驾驶员“分配”路线时,其余5个列表将有11个驾驶员可供选择,而选定的驾驶员也将被移除。依此类推。 这里的想法是只能给1个驾驶员分配一条路线。我有一个用于车辆的动态生成的相同列表,因此需要应用相同类型的逻辑。
我添加了以下功能,以禁用/突出显示列表中的选定值。我也将php和html修改为:
var a = <?php echo $a; ?>;
function removeDriver(){
var x = document.activeElement.value;
for(i=0; i<a; i++){
var elemname='driver_list'+ i;
if (elemname !== document.activeElement.id) {
if (x != ''){
var y = document.getElementById(elemname).options;
for(z=0; z<y.length; z++) {
if(y[z].value == x){
y[z].disabled=true;
y[z].style.color = 'red';
y[z].style.background = 'grey';
}
}
}
}
}
}
这可以与其他列表进行交互。但是,我想在用户改变主意时重新启用这些选项。