ASP.NET MVC Ajax呼び出しを開始しようとしています。
コントローラ:
public class AjaxTestController : Controller
{
//
// GET: /AjaxTest/
public ActionResult Index()
{
return View();
}
public ActionResult FirstAjax()
{
return Json("chamara", JsonRequestBehavior.AllowGet);
}
}
見る:
<head runat="server">
<title>FirstAjax</title>
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js"></script>
<script type="text/javascript">
$(document).ready(function () {
var serviceURL = '/AjaxTest/FirstAjax';
$.ajax({
type: "POST",
url: serviceURL,
data: param = "",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: successFunc,
error: errorFunc
});
function successFunc(data, status) {
alert(data);
}
function errorFunc() {
alert('error');
}
});
</script>
</head>
データを返すコントローラーメソッドでアラートを出力するだけです。上記のコードは、私のビューに「chamara」を印刷するだけです。アラートは発生していません。
更新
コントローラを以下のように変更すると、動作し始めます。それがなぜ今機能しているのか、私には明確な考えがありません。誰か説明してください。パラメータ「a」は関連していません。同じメソッド名とパラメータを持つ2つのメソッドを追加できないためです。これは解決策ではないかもしれませんが、機能します
public class AjaxTestController : Controller
{
//
// GET: /AjaxTest/
[HttpGet]
public ActionResult FirstAjax()
{
return View();
}
[HttpPost]
public ActionResult FirstAjax(string a)
{
return Json("chamara", JsonRequestBehavior.AllowGet);
}
}
{"name":"chamara"}
。次に、次のように読みますdata['name']