• 【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字符串时候,注意大小写。

  • 相关阅读:
    python中创建列表、元组、字符串、字典、集合
    python中字典的键不允许重复
    python中生成字典
    python中实现列表元素的倒序排列
    python中实现字典的逆向排列
    python中增加字典的键值对(项)、修改键值对的值
    python中访问字典
    Fortran 2003:完美还是虚幻?(节选)
    感谢裘宗燕老师!
    “符号化”的效用和缺失
  • 原文地址:https://www.cnblogs.com/cjw1115/p/5024523.html
Copyright © 2020-2023  润新知