我正在使用带有 Razor 视图的 MVC5。我的视图模型具有可为空枚举类型的属性。我使它可以为空,这样当用户加载页面时,他们必须选择一个选项并在他们没有选择任何内容时进行验证。
public class PaymentViewModel
{
[Required(ErrorMessage = "Please select a payment method", AllowEmptyStrings = false)]
public PaymentType? SelectedPaymentType { get; set; }
}
public enum PaymentType
{
CreditCard,
DirectDebit
}
在我看来,我有一个表单并正在调用提交,而提交又将控制器操作作为帖子调用。
我的观点的相关部分如下所示:
<div class="row button-group" data-toggle="buttons">
<div class="col-xs-6">
<label class="btn btn-tertiary">
@Html.RadioButtonFor(model => model.SelectedPaymentType, PaymentType.CreditCard, new {@Name = "payment-method", @Value = "credit", @Id="rdoCredit"})
Credit Card
</label>
</div>
<div class="col-xs-6">
<label class="btn btn-tertiary">
@Html.RadioButtonFor(model => model.SelectedPaymentType, PaymentType.DirectDebit, new {@Name = "payment-method", @Value = "debit", @Id="rdoDebit"})
Direct Debit
</label>
</div>
</div>
由于某种原因,我的 model.PaymentType 上的值始终为空,即使我选择了一个单选按钮。我添加了 @Id 属性,因为我注意到如果我没有指定一个 ID,它会被赋予相同的 ID,但这没有帮助。
我还测试了帖子中出现的另一个字符串属性,因此它似乎特定于该属性/单选按钮组。
如果我使该属性不可为空,它将设置为 CreditCard(作为枚举的第一个值),并且如果我选择 DirectDebit 单选选项并提交表单,它仍然说它是 CreditCard。
(我确信我可以将标签做得更好,但我现在关心的是让绑定正常工作
编辑。生成的html是:
<form method="post" action="/myapplication/payment" novalidate="novalidate">
....
<div data-toggle="buttons" class="row button-group">
<div class="col-xs-6">
<label class="btn btn-tertiary">
<input type="radio" checked="checked" value="credit" name="payment-method" id="rdoCredit">
Credit Card
</label>
</div>
<div class="col-xs-6">
<label class="btn btn-tertiary">
<input type="radio" value="debit" name="payment-method" id="rdoDebit">
Direct Debit
</label>
</div>
</div>
...
</form>