我需要根据变量的值禁用选择选项。该值类似于其中一个选择选项值,需要将其禁用。
对于前,
<select>
<option>Value a</option>
<option>Value b</option>
</select>
$variable = <some select option value>;
因此,如果变量等于值a,则需要在select选项中禁用它。
感谢。
答案 0 :(得分:26)
使用您当前的标记,这将有效:
$("select option:contains('Value b')").attr("disabled","disabled");
修改
var variable = "b"
$("select option:contains('Value " + variable + "')").attr("disabled","disabled");
$("select").prop("selectedIndex",-1)
答案 1 :(得分:19)
$("select option[value='"+ $variable + "']").attr('disabled', true);
答案 2 :(得分:9)
这应该是一个更快的解决方案
$('select').children('option[value="' + $variable + '"]').attr('disabled', true)
答案 3 :(得分:6)
假设您有以下标记
<select>
<option value="volvo">Volvo</option>
<option value="saab">Saab</option>
<option value="mercedes">Mercedes</option>
<option value="audi">Audi</option>
</select>
使用此jQuery,将禁用saab选项。
$("select option").each(function() {
var $thisOption = $(this);
var valueToCompare = "saab";
if($thisOption.val() == valueToCompare) {
$thisOption.attr("disabled", "disabled");
}
});