我有几个RadioButtonFor
(剃刀),我正在尝试制作一个 JQuery 脚本,当您检查另一个按钮时取消选中其他按钮。
我有一个模型,其中包含要传递给 Html Helper 和打印机名称的布尔数组:
public class Mymodel
{
public List<PrinterModel> printers { get; set; }
public bool noDefault { get; set; }
}
我PrinterModel
的如下:
public class Printermodel
{
public bool selected { get; set; }
public string printerName { get; set; }
}
在我看来,这给出了:
@using (Html.BeginForm()
{
<div class="form-group">
for (var i = 0; i < Model.printers.Count(); i++)
{
@Html.RadioButtonFor(m => m.printers[i].selected, new { @class = "default" });
@Html.Label(Model.printers[i].printerName);
<br/>
}
@Html.RadioButtonFor(m=>m.noDefaultRadio, new { @class = "noDefault", @checked= "checked" });
@Html.Label("No default printer");
</div>
}
我知道我可以.prop('checked', false)
在 JQuery 中使用来取消选中单选框,所以我在第一次播放时尝试取消选中默认按钮:
$('.default').change(function () {
if ($('.default:checked').length > 0) {
$('.noDefault').prop('checked', false);
}
else {
$('.noDefault').prop('checked', true);
}
});
这什么也没做,但适用于复选框,为什么?
另外,默认情况下@checked="checked"
不会RadioButtonFor
选中,我也尝试过@checked = true
哪个也不起作用。
有任何想法吗?
编辑当尝试name="default"
按照建议使用时,我在导航器中检查页面时看到以下输入:
<input data-val="true" id="printers_0__primarySelected" name="printers[0].primarySelected" type="radio" value="{ disabled = disabled }"