Razor Pages OnPost - 父页面能否使用在创建时传递给其部分的相同部分模型?
Razor Pages OnPost - Can the parent page use the same partial model that is passed to its partial on creation?
我查看了几个建议的帖子,并且一直在搜索类似的问题,但没有找到与此特定问题相关的任何内容。
我有一个使用了一些部分的 Razor 页面。
public class TasksModel : PageModel
{
[BindProperty]
public TaskModelCreate Create { get; set; }
public TasksModel(ITaskService taskService, IHttpContextAccessor httpContextAccessor)
{
_taskService = taskService;
_userId = GetUserId(httpContextAccessor);
Create = new TaskModelCreate(_userId);
}
public async Task OnPostCreate()
{
// What I would like to do:
// (Using this parameter: TaskModelCreate taskModel)
await _taskService.CreateUserTask(taskModel.UserTask);
// What I do now, which works but means that I will have to have a "GetX" method on a lot
// of things that just return a property:
var task = await Create.GetTask(_userId);
await _taskService.CreateUserTask(task);
}
}
TaskModelCreate 对象(部分页面的模型):
[BindProperty]
public string Name { get; set; }
[BindProperty]
public string Description { get; set; }
public bool IsCompleted { get; set; }
public UserTask UserTask => new UserTask(UserId, Name, Description);
public int UserId { get; set; } // For testing
public TaskModelCreate(int userId)
{
UserId = userId;
}
我已通过将 UserId 写入页面来验证部分模型是在 TasksModel 构造函数中创建的模型。
但是,当从视图提交新任务时,指定的 OnPost 方法总是接收到一个 TaskModelCreate 对象,其中 UserId 属性 为 0(我在测试期间的 UserId 为 1)——这让我相信表单在发布时创建一个新的 TaskModelCreate。
Name 和 Description 属性已按预期填写。
有没有办法指定发布的对象应该是给定的对象,而不是新对象?
我正在使用 Asp.Net Core Razor Pages(非 MVC 版本)。
编辑:
我也被要求分享这些观点,所以他们在这里。
父视图:
@model MyApp.UserInterface.Pages.TasksModel
@{
Layout = "_DashboardLayout";
ViewData["Title"] = "Tasks";
}
<div class="container-fluid">
<ul class="nav nav-tabs justify-content-start" id="taskTabs" role="tablist">
<li class="nav-item">
<a class="nav-link active" id="tasksActive-tab" data-toggle="tab" role="tab" href="#tasksActive" aria-controls="Active Tasks" aria-selected="true">Active Tasks</a>
</li>
<li class="nav-item">
<a class="nav-link" id="tasksCreate-tab" data-toggle="tab" role="tab" href="#tasksCreate" aria-controls="Create Task" aria-selected="false">Create Task +</a>
</li>
<li class="nav-item">
<a class="nav-link" id="tasksStats-tab" data-toggle="tab" href="#tasksStats" aria-controls="Statistics" aria-selected="false">Your Stats</a>
</li>
<li class="nav-item">
<a class="nav-link" id="tasksArchive-tab" data-toggle="tab" href="#tasksArchive" role="tab" aria-controls="Archive" aria-selected="false">Archive</a>
</li>
</ul>
<div class="tab-content" id="myTabContent">
<div class="tab-pane fade show active" id="tasksActive" role="tabpanel" aria-labelledby="tasksActive-tab">
<partial name="TaskPartials/_active" model="Model.Active" view-data="@ViewData"/>
</div>
<div class="tab-pane fade" id="tasksCreate" role="tabpanel" aria-labelledby="tasksCreate-tab">
<partial name="TaskPartials/_create" model="Model.Create" view-data="@ViewData"/>
</div>
<div class="tab-pane fade" id="tasksStats" role="tabpanel" aria-labelledby="tasksStats-tab">
<partial name="TaskPartials/_stats" model="Model.Stats" view-data="@ViewData"/>
</div>
<div class="tab-pane fade" id="tasksArchive" role="tabpanel" aria-labelledby="tasksArchive-tab">
<partial name="TaskPartials/_archive" model="Model.Archive" view-data="@ViewData"/>
</div>
</div>
我的部分观点:
@model Model.TaskModelCreate
@{ ViewData.TemplateInfo.HtmlFieldPrefix = "Create";
}
<h1> User: @Model.UserId</h1>
<form method="post" asp-page-handler="create">
<div class="container">
<div class="form-group">
<div class="input-group mb-sm-3">
<div class="input-group-prepend">
<span class="input-group-text" id="taskName" style="width: 6rem;">Name</span>
</div>
<input type="text" asp-for="Name" class="form-control" placeholder="Do something.."
aria-label="TaskName" aria-describedby="taskName" name="Name" />
</div>
<div class="input-group mb-sm-3">
<div class="input-group-prepend">
<span class="input-group-text" id="taskDescription" style="width: 6rem;">Description</span>
</div>
<input type="text" asp-for="Description" class="form-control" placeholder="I want to do X because Y." aria-label="TaskDescription"
aria-describedby="taskDescription" name="Description" />
</div>
<div class="input-group-append">
<button type="submit" class="btn btn-outline-primary" id="taskCreateButton">
Create
</button>
</div>
</div>
</div>
</form>
你可以在部分视图中添加<input asp-for="UserId" hidden />
到你的表单,这样当post时,它会是post UserId,这里是一个演示:
父视图(任务):
@page
@model RazorPage1.Pages.Test.TasksModel
<h1>Tasks</h1>
<partial name="_Partial1" model="@Model.Create" />
Tasks.cshtml.cs:
public class TasksModel : PageModel
{
[BindProperty]
public TaskModelCreate Create { get; set; }
public IActionResult OnGet() {
Create = new TaskModelCreate { UserId = 1, Name = "create", Description = "ssss", IsCompleted = true };
return Page();
}
public async Task OnPostCreate()
{
int userId = Create.UserId;
}
}
_Partial1(在form里加<input asp-for="UserId" hidden />
,如果要传IsCompleted,也可以加<input asp-for="IsCompleted" hidden />
):
@model TaskModelCreate
<h1> User: @Model.UserId</h1>
<form method="post" asp-page-handler="Create">
<input asp-for="UserId" hidden />
<input asp-for="IsCompleted" hidden />
<div class="container">
<div class="form-group">
<div class="input-group mb-sm-3">
<div class="input-group-prepend">
<span class="input-group-text" id="taskName" style="width: 6rem;">Name</span>
</div>
<input type="text" asp-for="Name" class="form-control" placeholder="Do something.."
aria-label="TaskName" aria-describedby="taskName" name="Name" />
</div>
<div class="input-group mb-sm-3">
<div class="input-group-prepend">
<span class="input-group-text" id="taskDescription" style="width: 6rem;">Description</span>
</div>
<input type="text" asp-for="Description" class="form-control" placeholder="I want to do X because Y." aria-label="TaskDescription"
aria-describedby="taskDescription" name="Description" />
</div>
<div class="input-group-append">
<button type="submit" class="btn btn-outline-primary" id="taskCreateButton">
Create
</button>
</div>
</div>
</div>
</form>
创建任务模型:
public class TaskModelCreate
{
[BindProperty]
public string Name { get; set; }
[BindProperty]
public string Description { get; set; }
public bool IsCompleted { get; set; }
//public UserTask UserTask => new UserTask(UserId, Name, Description);
public int UserId { get; set; } // For testing
public TaskModelCreate()
{
}
public TaskModelCreate(int userId)
{
UserId = userId;
}
}
结果:
我查看了几个建议的帖子,并且一直在搜索类似的问题,但没有找到与此特定问题相关的任何内容。
我有一个使用了一些部分的 Razor 页面。
public class TasksModel : PageModel
{
[BindProperty]
public TaskModelCreate Create { get; set; }
public TasksModel(ITaskService taskService, IHttpContextAccessor httpContextAccessor)
{
_taskService = taskService;
_userId = GetUserId(httpContextAccessor);
Create = new TaskModelCreate(_userId);
}
public async Task OnPostCreate()
{
// What I would like to do:
// (Using this parameter: TaskModelCreate taskModel)
await _taskService.CreateUserTask(taskModel.UserTask);
// What I do now, which works but means that I will have to have a "GetX" method on a lot
// of things that just return a property:
var task = await Create.GetTask(_userId);
await _taskService.CreateUserTask(task);
}
}
TaskModelCreate 对象(部分页面的模型):
[BindProperty]
public string Name { get; set; }
[BindProperty]
public string Description { get; set; }
public bool IsCompleted { get; set; }
public UserTask UserTask => new UserTask(UserId, Name, Description);
public int UserId { get; set; } // For testing
public TaskModelCreate(int userId)
{
UserId = userId;
}
我已通过将 UserId 写入页面来验证部分模型是在 TasksModel 构造函数中创建的模型。
但是,当从视图提交新任务时,指定的 OnPost 方法总是接收到一个 TaskModelCreate 对象,其中 UserId 属性 为 0(我在测试期间的 UserId 为 1)——这让我相信表单在发布时创建一个新的 TaskModelCreate。
Name 和 Description 属性已按预期填写。
有没有办法指定发布的对象应该是给定的对象,而不是新对象?
我正在使用 Asp.Net Core Razor Pages(非 MVC 版本)。
编辑:
我也被要求分享这些观点,所以他们在这里。
父视图:
@model MyApp.UserInterface.Pages.TasksModel
@{
Layout = "_DashboardLayout";
ViewData["Title"] = "Tasks";
}
<div class="container-fluid">
<ul class="nav nav-tabs justify-content-start" id="taskTabs" role="tablist">
<li class="nav-item">
<a class="nav-link active" id="tasksActive-tab" data-toggle="tab" role="tab" href="#tasksActive" aria-controls="Active Tasks" aria-selected="true">Active Tasks</a>
</li>
<li class="nav-item">
<a class="nav-link" id="tasksCreate-tab" data-toggle="tab" role="tab" href="#tasksCreate" aria-controls="Create Task" aria-selected="false">Create Task +</a>
</li>
<li class="nav-item">
<a class="nav-link" id="tasksStats-tab" data-toggle="tab" href="#tasksStats" aria-controls="Statistics" aria-selected="false">Your Stats</a>
</li>
<li class="nav-item">
<a class="nav-link" id="tasksArchive-tab" data-toggle="tab" href="#tasksArchive" role="tab" aria-controls="Archive" aria-selected="false">Archive</a>
</li>
</ul>
<div class="tab-content" id="myTabContent">
<div class="tab-pane fade show active" id="tasksActive" role="tabpanel" aria-labelledby="tasksActive-tab">
<partial name="TaskPartials/_active" model="Model.Active" view-data="@ViewData"/>
</div>
<div class="tab-pane fade" id="tasksCreate" role="tabpanel" aria-labelledby="tasksCreate-tab">
<partial name="TaskPartials/_create" model="Model.Create" view-data="@ViewData"/>
</div>
<div class="tab-pane fade" id="tasksStats" role="tabpanel" aria-labelledby="tasksStats-tab">
<partial name="TaskPartials/_stats" model="Model.Stats" view-data="@ViewData"/>
</div>
<div class="tab-pane fade" id="tasksArchive" role="tabpanel" aria-labelledby="tasksArchive-tab">
<partial name="TaskPartials/_archive" model="Model.Archive" view-data="@ViewData"/>
</div>
</div>
我的部分观点:
@model Model.TaskModelCreate
@{ ViewData.TemplateInfo.HtmlFieldPrefix = "Create";
}
<h1> User: @Model.UserId</h1>
<form method="post" asp-page-handler="create">
<div class="container">
<div class="form-group">
<div class="input-group mb-sm-3">
<div class="input-group-prepend">
<span class="input-group-text" id="taskName" style="width: 6rem;">Name</span>
</div>
<input type="text" asp-for="Name" class="form-control" placeholder="Do something.."
aria-label="TaskName" aria-describedby="taskName" name="Name" />
</div>
<div class="input-group mb-sm-3">
<div class="input-group-prepend">
<span class="input-group-text" id="taskDescription" style="width: 6rem;">Description</span>
</div>
<input type="text" asp-for="Description" class="form-control" placeholder="I want to do X because Y." aria-label="TaskDescription"
aria-describedby="taskDescription" name="Description" />
</div>
<div class="input-group-append">
<button type="submit" class="btn btn-outline-primary" id="taskCreateButton">
Create
</button>
</div>
</div>
</div>
</form>
你可以在部分视图中添加<input asp-for="UserId" hidden />
到你的表单,这样当post时,它会是post UserId,这里是一个演示:
父视图(任务):
@page
@model RazorPage1.Pages.Test.TasksModel
<h1>Tasks</h1>
<partial name="_Partial1" model="@Model.Create" />
Tasks.cshtml.cs:
public class TasksModel : PageModel
{
[BindProperty]
public TaskModelCreate Create { get; set; }
public IActionResult OnGet() {
Create = new TaskModelCreate { UserId = 1, Name = "create", Description = "ssss", IsCompleted = true };
return Page();
}
public async Task OnPostCreate()
{
int userId = Create.UserId;
}
}
_Partial1(在form里加<input asp-for="UserId" hidden />
,如果要传IsCompleted,也可以加<input asp-for="IsCompleted" hidden />
):
@model TaskModelCreate
<h1> User: @Model.UserId</h1>
<form method="post" asp-page-handler="Create">
<input asp-for="UserId" hidden />
<input asp-for="IsCompleted" hidden />
<div class="container">
<div class="form-group">
<div class="input-group mb-sm-3">
<div class="input-group-prepend">
<span class="input-group-text" id="taskName" style="width: 6rem;">Name</span>
</div>
<input type="text" asp-for="Name" class="form-control" placeholder="Do something.."
aria-label="TaskName" aria-describedby="taskName" name="Name" />
</div>
<div class="input-group mb-sm-3">
<div class="input-group-prepend">
<span class="input-group-text" id="taskDescription" style="width: 6rem;">Description</span>
</div>
<input type="text" asp-for="Description" class="form-control" placeholder="I want to do X because Y." aria-label="TaskDescription"
aria-describedby="taskDescription" name="Description" />
</div>
<div class="input-group-append">
<button type="submit" class="btn btn-outline-primary" id="taskCreateButton">
Create
</button>
</div>
</div>
</div>
</form>
创建任务模型:
public class TaskModelCreate
{
[BindProperty]
public string Name { get; set; }
[BindProperty]
public string Description { get; set; }
public bool IsCompleted { get; set; }
//public UserTask UserTask => new UserTask(UserId, Name, Description);
public int UserId { get; set; } // For testing
public TaskModelCreate()
{
}
public TaskModelCreate(int userId)
{
UserId = userId;
}
}
结果: