ASP.NET Core 2 MVC选择标记帮助器(下拉列表)所选项目并非总是反映值

时间:2019-07-11 18:29:18

标签: c# asp.net-mvc asp.net-core asp.net-core-tag-helpers

我正在处理一种在我的应用程序中操纵用户/员工数据的表格。

我有一个简单的下拉选择标签助手(后跟标签以输出当前值)来更改员工的区域销售经理分配:

<select asp-for="Employee.RegionalSalesManager" asp-items="Model.RegionalSalesManagers" disabled="@(Model.EmployeeRole == 1 ? null : "disabled")">
    <option value="0">Select...</option>
</select>
<label id="lblRegionalSalesManagerID">@((Model.Employee != null) ? Model.Employee.RegionalSalesManager.ToString() : @"")</label>

在最初从数据库加载Model.Empolyee时,此方法可以正常工作;在视图中,选择标签(下拉菜单)显示正确的项目(区域销售经理),并且在标签中输出匹配的值:

Good Drop-Down Menu

表格的另一部分允许更改员工的角色-根据角色,可能不需要分配区域销售经理。更改员工角色后,该表单将过帐;如果不需要区域销售经理分配,则Model.Employee.RegionalSalesManger值将清零:

[HttpPost, ValidateAntiForgeryToken]
public async Task<IActionResult> Index(UserManagementViewModel model)
{
    if (model.Employee != null)
    {
        switch (model.EmployeeRole)
        {
            case 2: // employee Role is Regional Sales Manager
                model.Employee.RegionalSalesManager = 0; // no need for assignment
                break;
        }
    }
    return View(await BuildModel(model));
}

刷新视图后,选择标签帮助器disabled="@(Model.EmployeeRole == 1 ? null : "disabled")中的逻辑即会启动并适当地禁用菜单,并且标签显示该值确实已成功归零;但是,当我期望菜单将显示“选择...”项时,菜单仍显示最后一个选择,因为该项对应于零值:

Unexpected Drop-Down Menu

最后再回发一次(通过将角色更改为不需要区域销售经理分配的时间),最终会将菜单项设置为“选择...”

我在这里想念什么?第一次回发后,将以预期值返回视图模型;为什么菜单选择没有更新?

1 个答案:

答案 0 :(得分:0)

我知道了。提交表单后,select标签助手的发布值“覆盖”(读为“设置”)模型上的值。您无法在POST控制器中更新模型值,并且不能期望select标签助手使用新值。