选择具有以某个字符串开头的id选择器的下拉列表

时间:2014-11-14 13:27:35

标签: javascript jquery

我有五个下拉列表,其id元素名为box_g1,box_g2,box_g3,box_g4和box_g5。我想在所有组合框中启用所有禁用的值,其中id选择器以box_g开头。

HTML:

<select name="n1" id="box_g1">
    <option value="Default">Default</option>
    <option value="A">A</option>
    <option value="B">B</option>
    <option value="C">C</option>
    <option value="D">D</option>
    <option value="E">E</option>
</select>

<select name="n2" id="box_g2" disabled="disabled">
    <option value="Disabled">Disabled</option>
    <option value="A">A</option>
    <option value="B">B</option>
    <option value="C">C</option>
    <option value="D">D</option>
    <option value="E">E</option>
</select>

<select name="n3" id="box_g3" disabled="disabled">
    <option value="Disabled">Disabled</option>
    <option value="A">A</option>
    <option value="B">B</option>
    <option value="C">C</option>
    <option value="D">D</option>
    <option value="E">E</option>
</select>
<select name="n4" id="box_g4" disabled="disabled">
    <option value="Disabled">Disabled</option>
    <option value="A">A</option>
    <option value="B">B</option>
    <option value="C">C</option>
    <option value="D">D</option>
    <option value="E">E</option>

</select>
<select name="n5" id="box_g5" disabled="disabled">
    <option value="Disabled">Disabled</option>
    <option value="A">A</option>
    <option value="B">B</option>
    <option value="C">C</option>
    <option value="D">D</option>
    <option value="E">E</option>

</select>

JQuery:

$(document).ready(function(){
    $("select").change(function(e){

        var id = $(this).attr("id");
        var value = this.value;

        $("select option").each(function(){

            var idParent = $(this).parent().attr("id");

            if(id != idParent){
                if(this.value == value){
                    this.disabled = true;
                }

                else if($("#box_g1 option:selected").val()!="Default"){
                    $("#box_g2").prop("disabled", false);
                    $("#box_g3").prop("disabled", false);
             $("#box_g4").prop("disabled", false);
                    $("#box_g5").prop("disabled", false);
                }else{
                    /*$("#box_g1").each(function(){
                        $("#box_g1 option").removeAttr("disabled",false);
                    });                     
                    $("#box_g2").prop("disabled",true).val('Disabled');
                    $("#box_g3").prop("disabled",true).val('Disabled');
                    $("#box_g4").prop("disabled",true).val('Disabled');
                    $("#box_g5").prop("disabled",true).val('Disabled');*/

                    defaultValues();
                }
            }
        });
    });
});

function defaultValues() {

        if ($("#box_g1").val() == "Default") {
            $("select[id^='box_g']").removeAttr("disabled",false); // added this line to enable all the values in all boxes but they are still disabled.
            $("#box_g2").attr("disabled", true).val('Disabled');

            $("#box_g3").attr("disabled", true).val('Disabled');

            $("#box_g4").attr("disabled", true).val('Disabled');

            $("#box_g5").attr("disabled", true).val('Disabled');

        } else {
            $("#box_g2").attr("disabled", false);
            $("#box_g3").attr("disabled", false);
            $("#box_g4").attr("disabled", false);
            $("#box_g5").attr("disabled", false);
        }
    }

任何人都可以帮忙解决这个问题。检查函数defaultValues()。我已经提到了评论。

2 个答案:

答案 0 :(得分:1)

您可以使用以下选项启用所有选项:

$('select[id^="box_g"] option').prop("disabled",false);

但由于代码中的行符号

,选择仍将被禁用

答案 1 :(得分:0)

如果要启用所有以“box_g”开头的选择框,您可以使用此

 $("select[id^='box_g']").find("option").prop("disabled",false);