0

如果我单击它,我有一个添加按钮,然后它会生成一个具有一个下拉列表的新行(允许多选),现在如果我在下次按下添加按钮时在下拉列表中选择了某个值,它将在一个下拉列表中生成相同的下拉列表新行,但我希望用户不应该能够在新创建的下拉菜单中选择以前选择的项目。即每个下拉菜单都应该选择唯一的值。

<select multiple="true" id="mySelect[0]">
  <option value="1" >Apple</option>
  <option value="2">Pear</option>
  <option value="3">Banana</option>
  <option value="4">Orange</option>
</select>
<select multiple="true" id="mySelect[1]">
  <option value="1" >Apple</option>
  <option value="2">Pear</option>
  <option value="3">Banana</option>
  <option value="4">Orange</option>
</select>
<select multiple="true" id="mySelect[2]">
  <option value="1" >Apple</option>
  <option value="2">Pear</option>
  <option value="3">Banana</option>
  <option value="4">Orange</option>
</select>

如果在第一个下拉菜单中选择了苹果,梨,那么在接下来的两个下拉菜单中,苹果选项应该被禁用并用红色着色。

4

1 回答 1

0

这应该让您对如何开始有一个很好的了解:

//cancels given event
function cancelEvent(ev) {
    ev.preventDefault();
    ev.returnValue = false; 
    ev.cancelBubble = true;
    return false;
}

function checkSelection(e) {
var oSel = e.target
var oPrvSel;

    for(var i=0; i<e.target.index; i++) {
        oPrvSel = document.getElementById("mySelect[" + i + "]");
        for(var j=0; j<oPrvSel.options.length; j++) {
            if (oPrvSel.options[j].text == e.target.options[e.target.selectedIndex].text) return cancelEvent(e);
        }
    }

}



//at instanciation of new elements:
var oSel = document.getElementById("mySelect[" + i + "]");
oSel.index = i;
oSel.addEventListener("keydown", checkSelection, false);
于 2012-05-30T23:51:40.573 回答