AJAX calls provide seamless server communication without page refreshes, significantly improving user experience. This guide demonstrates how to easily implement AJAX calls within ASP.NET MVC.
Let's examine a simple controller action:
<code class="language-csharp">public ActionResult FirstAjax() { return Json("chamara", JsonRequestBehavior.AllowGet); }</code>
The corresponding JavaScript AJAX call, leveraging Razor syntax for dynamic URL generation, looks like this:
<code class="language-javascript">$.ajax({ url: '@Url.Action("FirstAjax", "AjaxTest")', contentType: "application/json; charset=utf-8", dataType: "json", success: successFunc, error: errorFunc }); function successFunc(data, status) { alert(data); } function errorFunc() { alert('error'); }</code>
data
ParameterAn initial coding error involved an unnecessary data
attribute in the AJAX call, even though no data was being sent. Removing the data
parameter (e.g., data: param = ""
) resolved this. Using @Url.Action
within Razor ensures the URL correctly targets the controller and action.
For POST requests, include the data
parameter:
<code class="language-javascript">data: { a: "testing" },</code>
Your controller action must then be decorated with the [HttpPost]
attribute:
<code class="language-csharp">[HttpPost] public ActionResult FirstAjax(string a) { return Json("chamara", JsonRequestBehavior.AllowGet); }</code>
This comprehensive guide illustrates the straightforward process of making AJAX calls to your ASP.NET MVC controllers, highlighting common pitfalls and best practices for robust and efficient web development.
The above is the detailed content of How to Make AJAX Calls to ASP.NET MVC Controllers?. For more information, please follow other related articles on the PHP Chinese website!