根据先前选择的下拉列表删除选择下拉选项

时间:2015-02-26 05:36:54

标签: javascript jquery html coldfusion

我知道有一些我在这里看过的例子,但我仍然无法让我的jquery正常工作。

问题:如果用户从下拉列表#1中选择特定选项,则更改下拉列表中的选项#2如何完成此操作?

HTML / ColdFusion的:

<label>*Xpress Mod/Paint:</label> <cfselect name="xpress_mod_data">
<option value="Non-Xpress">Non Xpress 
<option value="3-Day">3-Day Xpress
</cfselect>

<label>Enclosure Type:</label> <cfselect name="enclosure_type">
<option value="global">Global 
<option value="server_optimized">Server Optimized 
</cfselect>

这是我的JQuery:

$('#xpress_mod_data').change(function() {

        if($(this).attr("value")=="3-Day") {
            $("#enclosure_type option[value='server_optimized']").remove();
        } else {
        $('#enclosure_type').append('<option value="server_optimized">Server Optimized');
        }

});

运行我的代码时发生了什么:应该追加的选项会一次又一次地添加。

2 个答案:

答案 0 :(得分:3)

你没有在你的html中使用id id="xpress_mod_data"这个缺少Check Demo here

HTML

   <select name="xpress_mod_data" id="xpress_mod_data">
        <option value="Non-Xpress">Non Xpress </option>
    <option value="3-Day">3-Day Xpress</option>
    </select>

    <label>Enclosure Type:</label>  
    <select name="enclosure_type" id="enclosure_type">
    <option value="global">Global  </option>
    <option value="server_optimized">Server Optimized  </option>
    </select>

Jquery的

$('#xpress_mod_data').change(function() {

 if($(this).val()=="3-Day") {
     console.log('test');
            $("#enclosure_type option[value='server_optimized']").remove();
        } else {
        $('#enclosure_type').append('<option value="server_optimized">Server Optimized');
        }

});

答案 1 :(得分:0)

为了获得更大的灵活性,您需要添加多个链式选择,拥有多个父级或使用Ajax来构建下拉列表,请查看jQuery Chained Selects插件。 (它大大简化了我需要5个可能的下拉工作的项目。)

http://www.appelsiini.net/projects/chained