Html.BeginForm在IE浏览器中发布HttpGet动作而不是HttpPost,在Chrome和Firefox中很好

时间:2012-08-15 08:43:18

标签: c# asp.net-mvc-3 razor

我的Razor视图中有以下内容:

 @using (Html.BeginForm("Edit", "MyController", FormMethod.Post))
{
    <div class="grid_1">&nbsp;</div>
    <div id="ValSummary"> @Html.ValidationSummary(false)</div>


    @Html.EditorFor(x => x.Role, MVC.Shared.Views.EditorTemplates.KeyValuePairSelectList, new { SelectListOptions = Model.RoleSelectList })<br /><br />
    @Html.EditorFor(x => x.Trust, MVC.Shared.Views.EditorTemplates.KeyValuePairSelectList, new { SelectListOptions = Model.TrustSelectList.OrderBy(x => x.Text) })<br /><br />
    @Html.EditorFor(x => x.GmcCode)<br /><br />


    <div class="createbutton">
        <input id="btnGoBack" type="button" value="Back"/>  
        <input id="btnSubmit" type="button" value="Submit" />
    </div>

}

在我的控制器中我有

[HttpGet]
public virtual ActionResult Edit(string id)
{
}

[HttpPost]
public virtual ActionResult Edit(ViewModel viewModel)
{
}

在Firefox和Chrome中,一切正常但在提交表单时在IE中,HttpGet操作被触发而不是HttpPost。

调用堆栈或IE开发人员工具控制台中没有线索。

我遗失了哪些明显的东西?

1 个答案:

答案 0 :(得分:7)

您的提交按钮应该是真实的submit button type="Submit"

<input id="btnSubmit" type="submit" value="Submit" />

在所有浏览器中正确提交表单。

有关进一步的差异,请参阅此SO问题:Difference between <input type='button' /> and <input type='submit' />