【发布时间】:2015-10-15 05:24:29
【问题描述】:
在我的 MVC 项目中,我使用 ajax 表单根据修改后的搜索词动态更新一些搜索结果。
在渲染Ajax.BeginForm() 方法时,它不会在页面上(在DOM 中)渲染<form> 标记
一切都设置好了,Jquery、Unobtrusive 和 AJAX 都被引用了,我在其他地方有工作 Ajax.BeginForm 实例
@using (Ajax.BeginForm("FilterSearch","Attachment", new AjaxOptions()
{
OnComplete = "updateSearchResults",
HttpMethod = "POST"
},new{}))
{
@Html.HiddenFor(model => model.AccountId)
@Html.HiddenFor(model => model.ContactId)
@Html.HiddenFor(model => model.OpportunityId)
@Html.TextBoxFor(model => model.SearchTerm, new { placeholder = "Search Term", @class = "header-search-box" })
<input type="submit" class="header-search-input" />
}
只是在 DOM 中呈现为
<input id="AccountId" name="AccountId" type="hidden" value="">
<input id="ContactId" name="ContactId" type="hidden" value="">
<input id="OpportunityId" name="OpportunityId" type="hidden" value="O6UJ9A001TB1">
<input class="header-search-box" id="SearchTerm" name="SearchTerm" placeholder="Search Term" type="text" value="">
<input type="submit" class="header-search-input">
【问题讨论】:
-
您的项目中是否存在格式错误的 HTML?另外,您是通过 DOM 调试器(如 Chrome 的检查器)还是通过查看源来检查它?如果存在任何类型的开始/结束标记不一致,Chrome(和其他)将无法正确显示结构(并且随后会丢失各种元素)。
-
通过检查器,因为页面本身是通过 AJAX 加载的,但是 HTML 中没有错误。在自己的页面中加载时,它会呈现 Form 标签
-
有嵌套表格的机会吗?长话短说,
Ajax.BeginForm无论如何都会输出<form>。我唯一能想到的是后处理(AJAX 处理程序)正在搞砸它([un]justly)。 -
它很可能是一个嵌套形式 - 好主意,我会检查一下。谢谢
-
太好了,感谢您的提示。页面上方有一个表格,不必要地一直向下到底部。如果您做出答案,则将其标记为正确:)
标签: ajax asp.net-mvc asp.net-mvc-3 asp.net-mvc-4 model-view-controller