模型 属性 对它在 razor 页面中绑定的输入值做了很多
Model property does much the value of the input it's bound within razor page
我正在使用剃刀页面构建网络应用程序。
我有两个模型 Dossier
和 Log
。我使用脚手架自动为 Dossier
生成了 crud razor 页面。
提交与日志模型绑定的表单时,它会创建一个带有 NumeroDeDossier = 1
的日志模型实体,即使我已将 Log.NumeroDeDossier 与表单中的隐藏输入绑定 [=] 19=].
日志模型:
public class Log
{
public int LogID { get; set; }
public int NumeroDeDossier { get; set; }
[ForeignKey("Agent")]
public int AgentID { get; set; }
public DateTime DateDeSortie { get; set; }
public DateTime DateDeRetour { get; set; }
public Log()
{
DateDeSortie = DateTime.Now;
}
档案模型:
public class Dossier
{
[Key]
public int NumeroDeDossier { get; set; }
[ForeignKey("Agent")]
public int AgentID { get; set; }
[ForeignKey("Placard")]
public string PlacardID { get; set; }
public int Tiroir { get; set; }
public bool ExFlag { get; set; }
public Dossier()
{
ExFlag = true;
}
}
我的档案 Index.cshtml
我显示档案列表。并且有一个按钮,如果单击它会显示一个 bootstrap 模式,带有一个表单输入。
@foreach (var item in Model.Dossier) {
<tr>
<td>
@Html.DisplayFor(modelItem => item.NumeroDeDossier)
</td>
<td>
@Html.DisplayFor(modelItem => item.AgentID)
</td>
<td>
@Html.DisplayFor(modelItem => item.PlacardID)
</td>
<td>
@Html.DisplayFor(modelItem => item.Tiroir)
</td>
<td>
@if(item.ExFlag)
{
<div class="situation in"></div>
}
else
{
<div class="situation out"></div>
}
</td>
<td>
<a asp-page="./Edit" asp-route-id="@item.NumeroDeDossier">تعديل</a> |
<a asp-page="./Details" asp-route-id="@item.NumeroDeDossier">تفاصيل</a> |
<a asp-page="./Delete" asp-route-id="@item.NumeroDeDossier">حذف</a> |
// here is the modal trigger
<a data-toggle="modal" data-target="#largeShoes" class="borrow">استعارة</a>
</td>
<div class="form-group" style="display:none">
// Added the input outside of the model to have an input for every item.
//vaue of the input is Numero de Dossier (When i change it with a const ("11" for exemple) ut works)
<input form="myform" asp-for="Log.NumeroDeDossier" class="form-control" value="@item.NumeroDeDossier"/>
<span asp-validation-for="Log.NumeroDeDossier" class="text-danger"></span>
</div>
</tr>
<div class="modal fade" id="largeShoes" tabindex="-1" role="dialog" aria-labelledby="modalLabelLarge" aria-hidden="true">
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
<h4 class="modal-title" id="modalLabelLarge">رجاء أدخل رقم تأجير المستعير</h4>
</div>
<div class="modal-body">
<form id="myform" method="POST">
<div asp-validation-summary="ModelOnly" class="text-danger"></div>
<div class="form-group">
<label class="control-label">رقم التأجير @item.NumeroDeDossier </label>
<input asp-for="Log.AgentID" class="form-control" />
<span asp-validation-for="Log.AgentID" class="text-danger"></span>
</div>
<div class="form-group">
<input type="submit" value="إضافة" class="btn btn-default" />
</div>
</form>
</div>
</div>
</div>
</div>
}
表单链接到 Index.cshtml.cs,它创建一个日志对象并将其添加到数据库 ONPOST
。
public async Task<IActionResult> OnPostAsync()
{
if (!ModelState.IsValid)
{
return Page();
}
_context.Log.Add(Log);
await _context.SaveChangesAsync();
return RedirectToPage("./Index");
}
您应该使用隐藏的表单字段而不是包含在带有 display: none
的元素中的文本字段。 display: none
将阻止元素被渲染,因此文本字段也永远不会被渲染。提交表单时,未呈现的文本字段也不包含在表单数据中。
所以因为 属性 是一个 int
但没有数据被发送,所以在创建对象时使用 int
的默认值。 int
的默认值为 0。
因此,改为使用具有常量值的隐藏表单字段:
<input type="hidden" asp-for="Log.NumeroDeDossier" value="@item.NumeroDeDossier" />
只需将其放入您的 <form>
标签即可。因为它有 type="hidden"
,所以它不会被渲染,但该值仍将作为表单请求的一部分发送。
我正在使用剃刀页面构建网络应用程序。
我有两个模型 Dossier
和 Log
。我使用脚手架自动为 Dossier
生成了 crud razor 页面。
提交与日志模型绑定的表单时,它会创建一个带有 NumeroDeDossier = 1
的日志模型实体,即使我已将 Log.NumeroDeDossier 与表单中的隐藏输入绑定 [=] 19=].
日志模型:
public class Log
{
public int LogID { get; set; }
public int NumeroDeDossier { get; set; }
[ForeignKey("Agent")]
public int AgentID { get; set; }
public DateTime DateDeSortie { get; set; }
public DateTime DateDeRetour { get; set; }
public Log()
{
DateDeSortie = DateTime.Now;
}
档案模型:
public class Dossier
{
[Key]
public int NumeroDeDossier { get; set; }
[ForeignKey("Agent")]
public int AgentID { get; set; }
[ForeignKey("Placard")]
public string PlacardID { get; set; }
public int Tiroir { get; set; }
public bool ExFlag { get; set; }
public Dossier()
{
ExFlag = true;
}
}
我的档案 Index.cshtml
我显示档案列表。并且有一个按钮,如果单击它会显示一个 bootstrap 模式,带有一个表单输入。
@foreach (var item in Model.Dossier) {
<tr>
<td>
@Html.DisplayFor(modelItem => item.NumeroDeDossier)
</td>
<td>
@Html.DisplayFor(modelItem => item.AgentID)
</td>
<td>
@Html.DisplayFor(modelItem => item.PlacardID)
</td>
<td>
@Html.DisplayFor(modelItem => item.Tiroir)
</td>
<td>
@if(item.ExFlag)
{
<div class="situation in"></div>
}
else
{
<div class="situation out"></div>
}
</td>
<td>
<a asp-page="./Edit" asp-route-id="@item.NumeroDeDossier">تعديل</a> |
<a asp-page="./Details" asp-route-id="@item.NumeroDeDossier">تفاصيل</a> |
<a asp-page="./Delete" asp-route-id="@item.NumeroDeDossier">حذف</a> |
// here is the modal trigger
<a data-toggle="modal" data-target="#largeShoes" class="borrow">استعارة</a>
</td>
<div class="form-group" style="display:none">
// Added the input outside of the model to have an input for every item.
//vaue of the input is Numero de Dossier (When i change it with a const ("11" for exemple) ut works)
<input form="myform" asp-for="Log.NumeroDeDossier" class="form-control" value="@item.NumeroDeDossier"/>
<span asp-validation-for="Log.NumeroDeDossier" class="text-danger"></span>
</div>
</tr>
<div class="modal fade" id="largeShoes" tabindex="-1" role="dialog" aria-labelledby="modalLabelLarge" aria-hidden="true">
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
<h4 class="modal-title" id="modalLabelLarge">رجاء أدخل رقم تأجير المستعير</h4>
</div>
<div class="modal-body">
<form id="myform" method="POST">
<div asp-validation-summary="ModelOnly" class="text-danger"></div>
<div class="form-group">
<label class="control-label">رقم التأجير @item.NumeroDeDossier </label>
<input asp-for="Log.AgentID" class="form-control" />
<span asp-validation-for="Log.AgentID" class="text-danger"></span>
</div>
<div class="form-group">
<input type="submit" value="إضافة" class="btn btn-default" />
</div>
</form>
</div>
</div>
</div>
</div>
}
表单链接到 Index.cshtml.cs,它创建一个日志对象并将其添加到数据库 ONPOST
。
public async Task<IActionResult> OnPostAsync()
{
if (!ModelState.IsValid)
{
return Page();
}
_context.Log.Add(Log);
await _context.SaveChangesAsync();
return RedirectToPage("./Index");
}
您应该使用隐藏的表单字段而不是包含在带有 display: none
的元素中的文本字段。 display: none
将阻止元素被渲染,因此文本字段也永远不会被渲染。提交表单时,未呈现的文本字段也不包含在表单数据中。
所以因为 属性 是一个 int
但没有数据被发送,所以在创建对象时使用 int
的默认值。 int
的默认值为 0。
因此,改为使用具有常量值的隐藏表单字段:
<input type="hidden" asp-for="Log.NumeroDeDossier" value="@item.NumeroDeDossier" />
只需将其放入您的 <form>
标签即可。因为它有 type="hidden"
,所以它不会被渲染,但该值仍将作为表单请求的一部分发送。