在表单周围添加<form>标签会禁用Razor代码来填充输入元素

acu*_*cie 0 html c# forms asp.net-mvc

我正在为事件数据模型创建一个编辑表单,其中输入元素使用Event属性进行填充以进行编辑.在我完成填充字段并格式化页面后,我意识到我忘记了表单标签.添加它们之后,我的Razor代码完全停止工作,将所有输入元素留空.我已经尝试禁用代码的各个部分,包括所有javascript和css,除了删除表单标记之外似乎没有重新填充字段.

这是代码:

@model Objects.Models.Event.Event

@using EventSignup.Extensions

@{
    ViewBag.Title = "Edit";
}

<script src="@Url.Content("~/Scripts/jquery-ui-1.8.22.min.js")" type="text/javascript"></script>
<link href="@Url.Content("~/Content/themes/base/jquery.ui.all.css")" rel="stylesheet" type="text/css" />
<script src="@Url.Content("~/Javascript/jquery-ui-timepicker-addon.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Javascript/Edit.js")" type="text/javascript" ></script>

<h2>Edit</h2>

<div class="hero-unit">
<form action="" id="event_form" method="post">
    <label for="name">Event Name:</label>
    <input type="text" name="name" id="name" value="@Model.EventName" /><br />

    <label for="tickets"># of Tickets:</label>
    <input type="text" name="tickets" id="tickets" value="@Model.Tickets" /><br />

    <label for="location">Location:</label>
    <select name="location" id="location">        
        @foreach (var Element in ViewBag.Buildings as List<EventSignup.ViewModels.SelectElement>)
        {
            <option value="@Element.ID" @((Model.TicketsLocation.ID == @Element.ID) ? "selected='selected'" : "")>@Element.DisplayName</option>
        }
    </select><br />

    <label for="dates">Dates/Times:</label>
    @foreach (var EventInfo in Model.Dates)
    {
        <input type="text" class="date" name="dates" id="dates@(Model.Dates.IndexOf(EventInfo)+1)" value="@EventInfo.DateTime.ToDateTimePickerString()"/><br />
        if (EventInfo != Model.Dates.Last())
        {
            <label></label>
        }
    }
    <div id="date_inputs">
    </div>
    <label></label>
    <span id="new_date" class="fauxlink" onclick="newDate()">New Date/Time</span><br /><br />
    <input type="hidden" id="num_dates" value="@Model.Dates.Count" />

    <input type="submit" id="submit" value="Submit" /><br />
</form>
</div>
Run Code Online (Sandbox Code Playgroud)

Ode*_*ded 9

不要直接使用表单元素 - 使用BeginFormHTML帮助程序:

@using (Html.BeginForm())
{

}
Run Code Online (Sandbox Code Playgroud)

您还应该将模板编辑器用于不同的模型属性:

@Html.EditorFor(model => model.EventName)
Run Code Online (Sandbox Code Playgroud)

更新:

如果标记无效("在属性末尾缺少,未正确关闭的元素等等),我通常会发现Visual Studio/Razor将停止工作(例如,没有智能感知).仔细检查您的标记,看看您有这样的错误.

  • 这似乎是一个愚蠢的论点.我很惊讶线程正在进行,只要它是.几乎每个MVC框架(包括rails)都具有HTML帮助程序的概念.如果你没有使用它们,你就不会利用所有可用的工具.没有理由让某人不抽象出凌乱的化妆,特别是如果他们希望以后能够进行大范围的系统更改(比如更改所有文本框).HTML帮助程序 - 不是实现,而是一般概念 - 是DRY的基础. (4认同)
  • @AndreCalil - 除了MVC是建立在这个抽象之上的吗?它使您的标记更清晰,更容易理解?它允许您利用平台? (2认同)