【Asp.net MVC】AJAXHelper 和jQueryAjax

在ASP.NET MVC中,有一个官方提供的AJAXHelper帮助我们做AJAX相关的东西。我用传统的jQuery AJAX技术和AJAXHelper分别实现同一个demo,特此记录一下。

由于是在MVC中,所以创建了一个Home控制器,里面有两个Action,Login()用于一个普通页面,GetInfo()用于返回一个json字符串,定义如下

public class HomeController : Controller
    {
        public ActionResult Login()
        {
            return View();
        }
        public JsonResult GetInfo()
        {
            return Json(new
            {
                time = DateTime.Now.ToString(),
                flag=new Info[] { new Info { Name="小明",Age=18 },new Info { Name="小秋",Age=19 } }
            },JsonRequestBehavior.AllowGet);
        }
    }
    public class Info
    {
        public string Name { get; set; }
        public int Age { get; set; }
    }

Info类是一个实体模型,主要是让返回的json字符串复杂一点,嘿嘿。

好了,后台完了,下面就分别给出两种不同的处理方法

一:jQuery AJAX:

  

<!DOCTYPE html>
<html> <head> <meta name="viewport" content="width=device-width" /> <title>Login</title> <script src="~/scripts/jquery-2.1.4.js"></script> <script src="~/scripts/jquery.unobtrusive-ajax.js"></script> <script type="text/javascript"> $(document).ready(function () { $("#get").click(function () { $.ajax({ cache:false, type: "get",
dataType:"json", url: "getinfo", success: function (data, textStatus) { $("#main").html(data.time); var bodyTag=$("body"); bodyTag.append("<table>"); $.each(data.flag, function () { $("body").append("<tr><td>"+this.Name+"</td><td>"+this.Age+"</td></tr>"); }) bodyTag.append("</table>"); } }); }) })
</script> </head> <body><input type="button" id="get" value="获取信息" /><div id="main"></div> </body> </html>

在上面的jQuery代码中,我在dom完成加载后,给id为“get”的按钮注册了一个点击事件,点击该按钮后会发起ajax请求,请求的方式为get,返回数据类型为json格式,然后再请求成功success的回调函数中我用了一些jquery的方法操作dom,把返回的数据显示出来。

以上就是用直接调用jQuery AJAX的方法,至于ajax的请求参数我们可以任意修改,留个参考网址:http://www.jquery123.com/jQuery.ajax/

二:利用AJAXHelper

@model WebApplication1.Models.UserViewModel
@{ 
    Layout = null;
}

<!DOCTYPE html>

<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Login</title>
    <script src="~/scripts/jquery-2.1.4.min.js"></script>
    <script src="~/scripts/jquery.unobtrusive-ajax.js"></script>
    <script type="text/javascript">
        function OnSuccess(data) {
            var main = document.getElementById("main");
            var table = document.createElement("table");
            for (var i = 0; i < data.flag.length; i++) {
                var tr = document.createElement("tr");
                tr.innerHTML = "<td>" + data.flag[i].Name + "</td>" + "<td>" + data.flag[i].Age + "</td>";
                table.appendChild(tr);
            }
            main.appendChild(table);
        }
    </script>
</head>
<body>
    @using (Ajax.BeginForm("getinfo",new AjaxOptions {OnSuccess= "OnSuccess", HttpMethod="Get", AllowCache=false}))
    {
        <input type="submit" id="get" value="获取信息" />
    }
   <div id="main">
    </div>
</body>
</html>

using的目的在于让表单标签闭合,可以看到AJAXHelper发起ajax请求也是比较简单。和jQuery AJAX直接操作没有区别,不过vs的智能提示还是不错的。这个只有在AJAXHelper中可以体验到。

 

总结:两种都能完成AJAX请求,但是AJAXHelper和jQuery AJAX是有区别的。具体区别等我研究通了再来记录。嘿嘿

 

做demo过程中遇到的几个问题:

1.当一个Action返回JsonResult类型时候,Json()方法如果不加JsonRequestBehavior.AllowGet参数,当用get方法请求时会发生500错误。

2.在dom中操作json字符串时候,注意大小写。

 

posted @ 2015-12-06 21:50  DemoApp  阅读(489)  评论(0编辑  收藏  举报