Ajax.BeginForm を使用して ajax リクエストを作成していますが、asp.net mvc は、UpdateTargetId で設定した div ではなく、新しいページに結果を表示します。ページに同じ名前の div が 1 つだけあることを確認しました。
生成されるマークアップは次のとおりです。
<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 の最新バージョンを使用しています。スクリプト エラーは発生しません。すべての ID が一意であること、すべての js 関数が存在し、エラーなしで動作することを再確認しました。マークアップは、入力をフォームに直接入れることはできませんが、他のページでは正常に機能することを除いて、HTML の厳密に有効です。サーバー側のコードは正常に実行され、返されたマークアップは完全に正しいものです。結果がdiv内ではなく新しいページに表示されることを除いて、すべて問題ないようです。私は何を間違っていますか?