ASP.Net Core Razor Pages动态列表

El *_*ano 5 c# razor-pages

我想用Razor页面创建一个网站来维护空间和相应的房间.所以,在我的模型中,空间有一个房间列表.

public class Space
{
    public int Id { get; set; }
    public string SpaceName { get; set; }
    public List<Room> Rooms { get; set; }

    public Space()
    {
        this.Rooms = new List<Room>();
    }
}
Run Code Online (Sandbox Code Playgroud)

在create.cshtml中,我想动态添加和删除房间

<h1>Create New Space</h1>
<form method="post">
    <div class="form-group">
       <label for="Space.SpaceName">Space Name</label>
       <input type="text" class="form-control" asp-for="Space.SpaceName" placeholder="Enter space name">
       <span asp-validation-for="Space.SpaceName" ></span>
    </div>
    @if(Model.Space != null){
        for (int i = 0; i < Model.Space.Rooms.Count; i++)
        {
         <input asp-for="@i" type="hidden" />
         <div class="form-group">
             <label for="SpaceName">Room Name</label>
             <input type="text" class="form-control" asp-for="Space.Rooms[i].Name" placeholder="Enter space name">
             <span asp-validation-for="Space.Rooms[i].Name" ></span>
         </div>

         <button type="submit" asp-page-handler="removeroom" asp-route-index="@i">Remove Room</button>
         }
    }

    <button type="submit" asp-page-handler="addroom">Add Room</button>

    <button type="submit" asp-page-handler="submit" class="btn btn-primary">Submit</button>
</form>
Run Code Online (Sandbox Code Playgroud)

PageModel看起来像这样:

public class CreateModel : PageModel
{
    readonly SpaceRepository spaceRepository;

    public CreateModel(SpaceRepository spaceRepository)
    {
        this.spaceRepository = spaceRepository;
    }

    [BindProperty]
    public Space Space { get; set; }

    public async Task<IActionResult> OnPostSubmitAsync()
    {
        if (!ModelState.IsValid)
        {
            return Page();
        }

        spaceRepository.Create(Space);
        return RedirectToPage("./Index");
    }

    public async Task OnPostAddRoomAsync()
    {
        Space.Rooms.Add(new Room());
    }

    public async Task OnPostRemoveRoomAsync(int index)
    {
        Space.Rooms.RemoveAt(index);
    }
}
Run Code Online (Sandbox Code Playgroud)

到目前为止,它按预期工作,但是当我创建例如3个房间并删除第一个或第二个房间时,它总是删除最后一个房间.

在处理程序发布后,该页面似乎没有收到操作列表.

有什么想法缺少什么?

谢谢您的帮助!

小智 1

我知道你可能不再需要它了,但我也遇到了问题,所以我在 github 上打开了一个问题,我得到了你问题的答案:https
://github.com/aspnet/Mvc/issues/8373 所以基本上 MVC 是往返模型,因此字段可以保持填充状态。因此,页面模型使用最后已知的模型状态来填充每个字段。Modelstate.Clear()您可以在删除项目后使用来修复此问题。因此,从列表中删除项目后,您也不会显示任何验证消息。