我知道有一些我在这里看过的例子,但我仍然无法让我的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');
}
});
运行我的代码时发生了什么:应该追加的选项会一次又一次地添加。
答案 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个可能的下拉工作的项目。)