1.Instructions
Je souhaite ouvrir la page "Créer", renseigner les données d'en-tête de la facture, renseigner les données de la ligne dynamique de la facture et tout enregistrer en une seule soumission.
(* code mis à jour) J'ai réussi à résoudre l'erreur RowList qui ne me permettait pas d'ajouter plusieurs lignes :
Comment utiliser AddRange pour insérer plusieurs lignes dans la page ASP.NET Core Razor
Maintenant, j'obtiens l'erreur
Erreur 1.1
ArgumentNullException : la valeur ne peut pas être nulle. (paramètre "source")
System.Linq.ThrowHelper.ThrowArgumentNullException (paramètre ExceptionArgument)
ArgumentNullException : la valeur ne peut pas être nulle. (paramètre "source")
System.Linq.ThrowHelper.ThrowArgumentNullException(ExceptionArgument argument) System.Linq.Enumerable.Count<TSource>(IEnumerable<TSource> source) EPIDENT5.Pages.Magazina.Pages_Magazina_Create.<ExecuteAsync>b__28_0() in Create.cshtml
...
@for (int i = 0; i < Model.RowList.Count(); i++)
Microsoft.AspNetCore.Razor.Runtime.TagHelpers.TagHelperExecutionContext.GetChildContentAsync(bool useCachedResult, encodeur HtmlEncoder) Microsoft.AspNetCore.Mvc.TagHelpers.RenderAtEndOfFormTagHelper.ProcessAsync (contexte TagHelperContext, sortie TagHelperOutput) Microsoft.AspNetCore.Razor.Runtime.TagHelpers.TagHelperRunner.g__Awaited|0_0 (tâche, TagHelperExecutionContextexecutionContext, int i, nombre int) EPIDENT5.Pages.Magazina.Pages_Magazina_Create.ExecuteAsync() dans Create.cshtml
ViewData["Title"] = "Create";
Je sais qu'il me manque quelque chose mais je ne comprends pas quel est le problème.
2.Question
Comment faire ça ?
<强>3. Code frontal :
<form method="post"> <div asp-validation-summary="ModelOnly" class="text-danger"></div> // This is the header table <table class="table table-striped border-0" style="width: 100%; text-align: left;"> <thead class="border-0"> <tr class="border-0"> <td class="border-0" style="min-width:100%;"> <div class="border border-secondary p-4"> <div class="row "> <div style="float:left;width:50%;"> <div class="form-group m-1"> <label asp-for="InvHeader.Cli" class="control-label" style="font-size:80%;">Client</label> <input asp-for="InvHeader.Cli" class="form-control" value="clients name" /> </div> </div> <div style="float:left;width:25%;"> <div class="form-group m-1"> <input asp-for="InvHeader.InvDate" class="form-control" type="date" value="@(DateTime.UtcNow.Date.ToString("yyyy-MM-dd"))" /> <span asp-validation-for="InvHeader.InvDate" class="text-danger"></span> </div> </div> <div style="float:left;width:25%;"> <div class="form-group m-1"> <input asp-for="InvHeader.InvNr" class="form-control" value="33" /> <span asp-validation-for="InvHeader.InvNr" class="text-danger"></span> </div> </div> </div> </div> </td> </tr> </thead> </table> //This is the dynamic rows table <table id="table1" border="0"> <tr style="font-size:80%;"> <th style="width:50%;">Product</th> <th style="width:5%;">qty</th> <th style="width:5%;">price</th> </tr> foreach (var item in Model.PL) { <tr class="border-bottom"> <td> <select id="Products" asp-for="@Model.PL[@i].ProdId" class="form-control" type="text" name="data[@i][ProdId]" style="width:100%;" > @foreach (var item in Model.PL) { <option value="@item.ProdId" qty="@qty" price="@Convert.ToInt32(item.price)">@item.name, @Convert.ToInt32(item.price)</option> } </select> </td> <td><input asp-for="@Model.MR[@i].qty" class="form-control" type="text" name="qty[@i]" style="width:100%;" /></td> <td><input asp-for="@Model.MR[@i].price" class="form-control" type="text" name="price[@i]" style="width:100%;" /></td> </tr> </table> </form>
4. Code back-end
//Partie de liaison de données
[BindProperty] public InvHeader InvHeader { get; set; } = default!; public IList<InvRow> RowList { get; set; }
//méthode onget, où le nombre de lignes est rouge
public IActionResult OnGetAsync() { var rr = new List<InvRow>() { new InvRow() { Name = "Apple", Qty = 5, Price = 100 }, new InvRow() { Name = "Peach", Qty = 3, Price = 500 }, new InvRow() { Name = "Ananas", Qty = 1, Price = 1100 }, }; RowList = rr; return Page(); }
//Méthode Onpost
public async Task<IActionResult> OnPostAsync(IList<InvRow> RowList) { if (!ModelState.IsValid) { return Page(); } _context.InvHeaders.Add(InvHeader); await _context.InvRows.AddRangeAsync(RowList); await _context.SaveChangesAsync(); return RedirectToPage("./Index"); }
La liaison de modèle lie les propriétés via l'attribut name. L'attribut de nom correct correspondant au paramètre devrait ressembler à :
addrows[index].propertyName
.Inputs liés à
PL
是什么,但似乎只有qty
和price
InvRows dans le modèle de pageindéterminé. Vous devez modifier les deux noms d'entrée comme suit :
Si l'élément select est également lié au modèle
addrows[@i].ProdId. Quoi qu'il en soit, le nom dépend de votre modèle.InvRows
模型相关,只需更改 select 名称,例如:addrows[@i].ProdId
InvRows, changez simplement le nom de sélection, par exemple :option
元素中没有qty
或price
Veuillez noter qu'il n'y a pas d'attributs