Je souhaite créer une option sous une forme telle que
[] I would like to order a [selectbox with pizza] pizza
où la boîte de sélection est activée uniquement lorsque la case est cochée et désactivée lorsqu'elle n'est pas cochée.
Je viens avec ce code:
<form>
<input type="checkbox" id="pizza" name="pizza" value="yes"> <label for="pizza">
I would like to order a</label>
<select name="pizza_kind">
<option>(choose one)</option>
<option value="margaritha">Margaritha</option>
<option value="hawai">Hawai</option>
</select>
pizza.
</form>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js">
</script>
<script>
var update_pizza = function () {
if ($("#pizza").is(":checked")) {
$("#pizza_kind").removeAttr("disabled");
}
else {
$("#pizza_kind").prop('disabled', 'disabled');
}
};
$(update_pizza);
$("#pizza").change(update_pizza);
</script>
J'ai essayé différentes méthodes comment définir l' attribut désactivé à l' aide .prop()
, .attr()
et .disabled=
. Cependant, rien ne se passe. Lors de l'application à un <input type="checkbox">
au lieu de <select>
, le code fonctionne parfaitement.
Comment désactiver / activer à l' <select>
aide de jQuery?