【问题标题】:ASP.NET Core: Modal does not pass values to controller methodASP.NET Core:模态不会将值传递给控制器​​方法
【发布时间】:2020-10-21 07:19:41
【问题描述】:

我的索引包含一个表格,其中显示了我创建的所有问题(调查)。但我希望能够使用模态编辑问题。因此,我在 foreach 循环中创建了以下模式:

 @foreach (var item in Model.Questions)
    {
        <tr>
            <td>
                @Html.DisplayFor(modelItem => item.Id)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.Question1)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.ReplyOptions)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.Group)
            </td>
            <td>
                @if (item.CategoryId != null)
                {
                    @Html.DisplayFor(modelItem => item.Category.Name)
                }
                else
                {
                    <i><font color="red">Nicht zugewiesen</font></i>
                }
            </td>
            <td>
                <!-- Button trigger modal -->
                <button type="button" class="btn btn-sm" data-toggle="modal" data-target="#@item.Id">
                    Bearbeiten
                </button>

                <!-- Modal -->
                <div class="modal fade" id="@item.Id" tabindex="-1" role="dialog" aria-labelledby="xxx" aria-hidden="true">
                    <div class="modal-dialog" role="document">
                        <div class="modal-content">
                            <div class="modal-header">
                                <button type="button" class="close" data-dismiss="modal" aria-label="Close">
                                    <span aria-hidden="true">&times;</span>
                                </button>
                                <h2 class="modal-title" id="xxx">Frage bearbeiten</h2>
                            </div>
                            <div class="modal-body">
                                <form asp-action="Edit">
                                    <div asp-validation-summary="ModelOnly" class="text-danger"></div>
                                    <input type="hidden" asp-for="@item.Id" />
                                    <div class="form-group">
                                        <label asp-for="@item.CategoryId" class="control-label"></label>
                                        <select asp-for="@item.CategoryId" class="form-control" asp-items="ViewBag.CategoryId"></select>
                                        <span asp-validation-for="@item.CategoryId" class="text-danger"></span>
                                    </div>
                                    <div class="form-group">
                                        <label asp-for="@item.Question1" class="control-label"></label>
                                        <input asp-for="@item.Question1" class="form-control" />
                                        <span asp-validation-for="@item.Question1" class="text-danger"></span>
                                    </div>
                                    <div class="form-group">
                                        <label asp-for="@item.ReplyOptions" class="control-label"></label>
                                        <input asp-for="@item.ReplyOptions" class="form-control" />
                                        <span asp-validation-for="@item.ReplyOptions" class="text-danger"></span>
                                    </div>
                                    <div class="form-group">
                                        <label asp-for="@item.Group" class="control-label"></label>
                                        <input asp-for="@item.Group" class="form-control" />
                                        <span asp-validation-for="@item.Group" class="text-danger"></span>
                                    </div>
                                    <div class="modal-footer">
                                        <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
                                        <button type="submit" class="btn btn-primary">Save</button>
                                    </div>
                                </form>
                            </div>
                        </div>
                    </div>
                </div>
                <a asp-action="Delete" asp-route-id="@item.Id">Delete</a>
            </td>
        </tr>
    }

但是我有以下问题: 当我想编辑问题并单击“保存”时,控制器中的“编辑”方法无法获取值。 该方法如下所示:

我必须做些什么来确保传递这些值?

【问题讨论】:

    标签: c# html razor asp.net-core-mvc


    【解决方案1】:

    我必须做些什么来确保传递这些值?

    只需为表单中的每个控件添加 name 属性即可:

      <div class="modal-body">
                                    <form asp-action="Edit">
                                        <div asp-validation-summary="ModelOnly" class="text-danger"></div>
                                        <input type="hidden" asp-for="@item.Id" name="Id" />
                                        <div class="form-group">
                                            <label asp-for="@item.CategoryId" class="control-label"></label>
                                            <select asp-for="@item.CategoryId" class="form-control" asp-items="ViewBag.CategoryId" name="CategoryId"></select>
                                            <span asp-validation-for="@item.CategoryId" class="text-danger"></span>
                                        </div>
                                        <div class="form-group">
                                            <label asp-for="@item.Question1" class="control-label"></label>
                                            <input asp-for="@item.Question1" class="form-control" name="Question1" />
                                            <span asp-validation-for="@item.Question1" class="text-danger"></span>
                                        </div>
                                        <div class="form-group">
                                            <label asp-for="@item.ReplyOptions" class="control-label"></label>
                                            <input asp-for="@item.ReplyOptions" class="form-control" name="ReplyOptions" />
                                            <span asp-validation-for="@item.ReplyOptions" class="text-danger"></span>
                                        </div>
                                        <div class="form-group">
                                            <label asp-for="@item.Group" class="control-label"></label>
                                            <input asp-for="@item.Group" class="form-control" name="Group" />
                                            <span asp-validation-for="@item.Group" class="text-danger"></span>
                                        </div>
                                        <div class="modal-footer">
                                            <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
                                            <button type="submit" class="btn btn-primary">Save</button>
                                        </div>
                                    </form>
                                </div>
                            
    

    这是测试结果:

    【讨论】:

    • 非常感谢!! :D 但我想再问你一个问题:我还有一个用于创建问题的模式,并且它也可以在没有“名称”属性的情况下工作。为什么在这种情况下我需要它?
    • @Toasty,asp-for会自动生成name属性,关键在于name属性的形式。你的初始代号自动生成item.filedName的值,但是在action中接受的Question类没有item外域,所以你需要添加name属性来覆盖asp-for自动生成的名称。你提到的可以直接传输数据的案例说明asp-for自动生成的名字和后面代码中接收到的类结构是一致的。您可以使用 F12 查看呈现的 html。
    猜你喜欢
    • 2020-12-18
    • 1970-01-01
    • 1970-01-01
    • 2021-12-14
    • 1970-01-01
    • 2021-07-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多