zoukankan      html  css  js  c++  java
  • 如何构建 MVC&AJax&JSon示例

    背景:

      博客中将构建一个小示例,用于演示在ASP.NET MVC4项目中,如何使用JQuery Ajax。

      直接查看JSon部分

    步骤:

    1,添加控制器(HomeController)和动作方法(Index),并为Index动作方法添加视图(Index.cshtml),视图中HTML如下:

    复制代码
    输入你的姓名:
    <input type="text" id="txtName"/><br/>
    输入你的年龄:
    <input type="text" id="txtAge" /><br />
    <button type="button" id="btn1">提交</button>
    <button type="button" id="btn2">清空</button>
    <p id="display"></p>
    复制代码

      视图中包含两个文本框,分别用来输入名字和年龄,包含连个按钮,分别用来提交信息和清空文本框的内容,同时包含一个段落,用来显示Ajax返回的数据信息。

    2,在Home控制器中添加另外一个动作方(AddUsers),用来接收并处理视图传递过来的数据,并返回执行结果给视图,代码如下:

    复制代码
     1         public ActionResult AddUsers()
     2         {
     3             var my = new MyModel();
     4             string result = string.Empty;
     5             if(Request.IsAjaxRequest())
     6             {
     7                 this.UpdateModel(my);
     8                 string name = my.Name;
     9                 int age = my.Age;
    10                 if (age < 18) result = name+"的文章好烂啊";
    11                 else result = name+",记得烂也要写";
    12             }
    13             return Content(result);
    14         }
    复制代码

      如代码所示:直接用Content返回一个字符串。

      或者是返回一个 ContentResult()对象,与上面的代码类似(可以折叠了),代码如下:

    复制代码
     1         public ActionResult DoWithUsers()
     2         {
     3             var actionResult = default(ContentResult);
     4             var my = new MyModel();
     5             try
     6             {
     7                 this.UpdateModel(my);
     8                 string name = my.Name;
     9                 int age = my.Age;
    10                 string temp = "";
    11                 if (age < 18) temp = "的文章好烂啊";
    12                 else temp = ",记得烂也要写";
    13                 actionResult = new ContentResult()
    14                 {
    15                     Content = name + temp
    16                 };  
    17             }
    18             catch(Exception ex)
    19             {
    20                 return null;
    21             }
    22             return actionResult;
    23         }
    复制代码

    3,修改Jquery&Ajax代码:

    复制代码
     1     $(document).ready(function () {
     2         $("#btn1").click(function () {
     3             var data = "";
     4             var name = $("#txtName").val();
     5             var age = $("#txtAge").val();
     6             data += "&Name=" + encodeURI(name);
     7             data += "&Age=" + encodeURI(age);
     8             $.ajax({
     9                 async: true,
    10                 cache: false,
    11                 timeout: 60 * 60 * 1000,
    12                 data: data,
    13                 type: "GET",
    14                 datatype: "JSON",
    15                 url: "/Ajax/AddUsers",
    16                 success:function(result)
    17                 {
    18                     $("#display").text(result);
    19                 },
    20                 error: function (result) {
    21                     $("#display").html("error");
    22                 },
    23             })
    24         });
    复制代码

    4,运行效果如图:

     以上,最简单的ASP.NET MVC4&JQuery&AJax示例完成了。


    以Json方式发送Action处理后的结果:

    更多的情况下,不止是返回一个字符串,而是以Json的方式返回结果。

    5,修改Action如下:

    复制代码
     1         public ActionResult DoWithUsers()
     2         {
     3             var my = new MyModel();
     4             try
     5             {
     6                 this.UpdateModel(my);
     7                 string name = my.Name;
     8                 int age = my.Age;
     9                 string temp = "";
    10                 if (age < 18) temp = "的文章好烂啊";
    11                 else temp = ",记得烂也要写";
    12                 JavaScriptSerializer jss = new JavaScriptSerializer();
    13                 return Json(jss.Serialize(new { Name = name, Message = temp }), JsonRequestBehavior.AllowGet);
    14             }
    15             catch(Exception ex)
    16             {
    17                 return null;
    18             }
    19         }
    复制代码

    说明:JSon方法返回一个JSonResult,而JSonResult同样是继承自ActionResult的。

    6,修改AJax部分,代码如下:

    1                 success:function(result)
    2                 {
    3                     result = JSON.parse(result);
    4                     $("#display").text(result.Name + result.Message);
    5                 },

    运行效果一致。
    以上,最简单的ASP.NET MVC4&JQuery&AJax&JSon示例完成。

    出处:http://www.cnblogs.com/SharpL/p/4641040.html

  • 相关阅读:
    测试平台系列(56) JSON深层次对比方案
    测试平台系列(57) 美化代码编辑器
    测试平台系列(54) 数据库表接口适配前端页面(下)
    测试平台系列(55) 引入AceEditor(代码编辑器)
    测试平台系列(52) 改造异步数据库连接方案
    测试平台系列(53) 数据库表接口适配前端页面(上)
    二叉树
    OCP 063中文考试题库(cuug内部资料)第34题
    OCP 063中文考试题库(cuug内部资料)第33题
    OCP 063中文考试题库(cuug内部资料)第32题
  • 原文地址:https://www.cnblogs.com/mq0036/p/9082493.html
Copyright © 2011-2022 走看看