asp.net MVC多按钮形式
本文关键字:按钮 net MVC asp | 更新日期: 2023-09-27 18:34:14
如何使这部分代码
<ol>
@foreach (var role in ViewBag.RolesForThisUser)
{
<li>@role <input type="hidden" name="DeleteRoleName" value="@role" /><input type="submit" value="Delete" name="action:DeleteRole" /></li>
}
</ol>
发布我需要控制器的内容。现在,它会在列表中发布第一个角色(无论我单击哪个按钮)。通常我为每个列表选项做多个表单,但这次该列表位于其他表单中。我可以把表格变成表格吗?
一切都在一个帖子表格中:
@using (Html.BeginForm("GetUserRoles", "Manage"))
{
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
<p>
Users: @Html.DropDownList("UserName", (IEnumerable<SelectListItem>)ViewBag.Users, "Select ...")
<input type="submit" value="Get roles" name="action:GetUserRoles" />
</p>
if (ViewBag.RolesForThisUser != null)
{
<hr />
<p>
<text> Role name: </text>@Html.DropDownList("RoleName", (IEnumerable<SelectListItem>)ViewBag.Roles, "Select ...")
<input type="submit" value="Add role" name="action:AddRole" />
</p>
<hr/>
<p>
<text>User roles:</text>
<ol>
@foreach (var role in ViewBag.RolesForThisUser)
{
<li>@role <input type="hidden" name="DeleteRoleName" value="@role" /><input type="submit" value="Delete" name="action:DeleteRole" /></li>
}
</ol>
</p>
}
if (ViewBag.Action != null)
{
<hr />
<p>
@ViewBag.Action
</p>
}
}
请帮忙。谢谢托马斯
您不能嵌套表单,最好使用 ajax 发布到控制器操作,该操作包含将角色添加为表单数据或参数所需的信息。在手动设置参数的打开表单标记中设置的提交操作。您还可以使用 javascript 根据按钮单击更改提交时的表单属性,但使用标准输入会更容易遵循,这些输入使用您要提交的每一行的数据字段触发 ajax 调用。form.onSubmit 属性将允许您向表单操作中的同一操作添加参数。button.onClick 属性允许您构造 ajax 调用,该调用将转到特定的控制器和操作来处理您的逻辑。
问题以不同的方式解决(3 种形式 - 在 ViewBag 中传递用户名):
@using (Html.BeginForm("GetUserRoles", "Manage"))
{
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
<p>
Users: @Html.DropDownList("UserName", (IEnumerable<SelectListItem>)ViewBag.Users, "Select ...")
<input type="submit" value="Get roles" name="action:GetUserRoles" />
</p>
}
@if (ViewBag.RolesForThisUser != null)
{
<hr/>
<p>
<text>User roles:</text>
<ol>
@foreach (var role in ViewBag.RolesForThisUser)
{
using (Html.BeginForm("GetUserRoles", "Manage"))
{
@Html.AntiForgeryToken()
<li>@role
<input type="hidden" name="UserName" value="@ViewBag.User" />
<input type="hidden" name="DeleteRoleName" value="@role" />
<input type="submit" value="Delete" name="action:DeleteRole" /></li>
}
}
</ol>
</p>
}
@using (Html.BeginForm("GetUserRoles", "Manage"))
{
@Html.AntiForgeryToken()
if (ViewBag.RolesForThisUser != null)
{
<p>
<text> Role name: </text>
@Html.DropDownList("RoleName", (IEnumerable<SelectListItem>)ViewBag.Roles, "Select ...")
<input type="hidden" name="UserName" value="@ViewBag.User" />
<input type="submit" value="Add role" name="action:AddRole"/>
</p>
}
}