Я использую Ajax.BeginForm для выполнения запроса ajax, но asp.net mvc отображает результаты на новой странице вместо div, который я установил в UpdateTargetId. Я гарантировал, что у меня есть только один div с тем же именем на странице.
Сгенерированная разметка:
<form action="/MyController/MyAction" id="myform" method="post" onsubmit="Sys.Mvc.AsyncForm.handleSubmit(this, new Sys.UI.DomEvent(event), { insertionMode: Sys.Mvc.InsertionMode.replace, updateTargetId: 'myDiv', onSuccess: Function.createDelegate(this, someJsFunction) });">
<input type="text" name="name" id="userInput" value="" />
<input type="submit" id="mySubmit" style="display:none" />
</form><div id="myDiv"></div>
Здесь кнопка отправки не отображается, потому что я щелкаю ее с помощью JavaScript (я использую тот же метод на другой странице, которая работает):
$(document).ready(function() {
$("[name:'name']").bind("keyup", function() {
$("#mySubmit").click();
})
Я использую последнюю версию asp.net mvc. Я не получаю ошибок скрипта, я дважды проверил, все идентификаторы уникальны, все функции js существуют и работают без ошибок. Разметка строго верна в формате HTML, за исключением того, что входные данные не могут быть непосредственно в форме, но это прекрасно работает на других страницах. Серверный код выполняется успешно, и возвращаемая разметка совершенно верна. Все выглядит хорошо, за исключением того, что результат отображается на новой странице, а не внутри моего div. Что я делаю не так?