【发布时间】:2018-10-15 18:53:18
【问题描述】:
我正在创建一个新的 .net 核心 MVC 项目,供人们用来提交提案以在会议上进行演示。
对于提案提交表单,我使用绑定模型(AKA 视图模型)来绑定用户在表单上的输入。
下面是绑定模型类的部分代码:
public class BaseSubmissionBindingModel
{
public BaseSubmissionBindingModel(){
}
[Required]
public int ConferenceId { get; set; }
[Required]
[StringLength(250)]
[Display(Name = "Title")]
public string SubmissionTitle { get; set; }
[Required]
[StringLength(1000)]
[Display(Name = "Abstract")]
public string SubmissionAbstract { get; set; }
public IEnumerable<SelectListItem> SubmissionCategoryItems { get; set; }
[Required]
[Display(Name = "Select the Submission Category ")]
public string SelectedSubmissionCategory { get; set; }
}
注意字段 SubmissionCategoryItems - 此字段用于填充视图中的下拉选择表单控件。此控件的数据来自数据库查询,显示哪些提交类别取决于会议 ID 值。
在控制器类中,我获取会议 ID 的提交类别,并为每个提交类别创建一个带有 SelectListItem 对象的List<SelectListItem> submissionCategoryItems。
然后我创建 BaseSubmissionBindingModel 对象并将submissionCategoryItems 分配给BaseSubmissionBindingModel IEnumerable<SelectListItem> SubmissionCategoryItems。
然后控制器返回 View(baseSubmissionBindingModel)。
用户输入的视图页面正确呈现,并且“选择提交类别”选择框具有每个提交类别的正确选项。
以下是创建提交表单的 HTML
<div class="form-group">
<label asp-for="SelectedSubmissionCategory"></label>
<select asp-for="SelectedSubmissionCategory" asp-items="@Model.SubmissionCategoryItems">
<option value="" selected>--select--</option>
</select>
<span asp-validation-for="SelectedSubmissionCategory"></span>
</div>
如果用户没有在表单上输入所需的值,然后单击表单的提交按钮,就会出现我的问题。
我的控制器类有下面的 CreateSubmission 方法,当用户点击表单上的提交时会调用该方法
public IActionResult CreateSubmission(BaseSubmissionBindingModel baseSubmissionBindingModel) {
if (! ModelState.IsValid) {
return View("Index", baseSubmissionBindingModel);
}
Log.Information("Submission data provided is " + baseSubmissionBindingModel.ToString());
return View("Success", baseSubmissionBindingModel);
}
如果用户提交表单时未提供所有必需的数据,则模型的状态无效。初始视图与验证错误消息一起返回给用户。
但是,提交类别的选择框不再有从数据库中检索到的提交类别的任何选项。所以用户不能再选择提交类别。
如果用户最初未能提供所有必需的数据但仍提交表单,我如何确保提交类别选择框仍有其选项元素?
感谢您的帮助。
布鲁斯
【问题讨论】:
-
当您返回视图时,您尚未在 POST 方法中重新填充
SubmissionCategoryItems(就像您在 GET 方法中所做的那样) -
请注意,您不应该在标签选项中添加
selected属性 -TagHelper将根据SelectedSubmissionCategory的值设置正确的选项
标签: asp.net-mvc razor asp.net-core-mvc