2

所以我有一个局部视图,在其中我正在创建一个表单

@using(Html.BeginForm("UpdateTimesheet", "Entry", FormMethod.Post, new { id = @i }))
{
    <td>@Html.DropDownListFor(x => x.TimeEntry.LocationId, Model.LocationList, "Please select a location")</td>
    <td>@Html.DropDownListFor(x => x.TimeEntry.Equipment.Code, Model.EquipmentList, "Please select equipment")</td>
    <td>@Html.DropDownListFor(x => x.TimeEntry.Staff.PayrollId, Model.StaffList, "Please select staff")</td>
    <td>@Html.DropDownListFor(x => x.TimeEntry.Task.Name, Model.TaskList, "Please select a task")</td>
    <td>@Html.EditorFor(x => x.TimeEntry.LengthOfTime)</td>
    <td>@Html.DisplayFor(x => x.TimeEntry.EventDateTime)</td>
    <td>@Html.DisplayFor(x => x.TimeEntry.ReceivedDateTime)</td>
    <td>
        @Html.ActionLink("Cancel", "DisplayTimesheet", new { id = Model.TimeEntry.Id }, new { @class = "edit" })
        | 
        <a style="cursor: pointer" onclick="submitEdit(@i);">Save</a>
    </td>
}

但是正在呈现的 HTML 会立即关闭表单,然后是花括号内的 html。例如:

<form action="/Entry/UpdateTimesheet" id="edit1" method="post"></form>
<td>
    <select data-val="true" data-val-number="The field LocationId must be a number." id="TimeEntry_LocationId" name="TimeEntry.LocationId">
        <option value="">Please select a location</option>
        <option value="1">Location 1</option>
        <option selected="selected" value="3">Location 1</option>
    </select>
</td>

等等。这个局部视图被插入到表行 ()

任何想法为什么会发生这种情况以及我该如何解决?

4

2 回答 2

3

这可能与您尝试将表单放在 td 标签上有关,这基本上将表单放在 tr 中;这是不正确的。您应该尝试将表单放在 td 内部而不是外部。

于 2013-05-08T02:16:41.390 回答
1

您不需要在 BeginForm 参数中包含“@”。

@using(Html.BeginForm("UpdateTimesheet", "Entry", FormMethod.Post, new { id = i }))会正常工作。

于 2013-05-08T01:41:24.573 回答