• [转]如何在.NET MVC中使用jQuery并返回JSON数据


    本文转自:http://blog.sina.com.cn/s/blog_48e42dc90100xp1p.html

    二、开始实践 - jQuery端

    假设我们要从服务器端获取一个文章列表,并把文章条目显示在页面中,而加载的过程要用ajax实现,即实现异步加载。那么我们先来完成jquery向服务器端发出ajax请求,并根据服务器响应来重组DOM从而实现文章在页面上显示。这里,和.NET MVC没有多大关系。具体的jquery代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $.ajax({
    url: '/cgi/getArtical', //请求的某个action的地址
    datatype: "json", //只有指定为json下面才可以直接用返回的json数据,否则要转化
    type: 'post',
    success: function (data) {
    PutArtical(data); //该函数中处理json格式的文章数据data;
    HideTip(); //处理完文章后关闭加载提示
    },
    beforeSend: function(){
    LoadTip("正在加载文章"); //这里是加载过程中的等待提示,可以自己定义
    }
    })

    这是一个普通的jquery中ajax调用的例子,需要注意的是datatype最好指定为json,因为下面服务器端是直接返回json对象的,这样success中返回的数据就直接是json对象,可以直接使用;如果不这样指定的话也行,不过在success函数中必须先把data转换成json对象,转换方法是eval_r('('+data+')')。

    三、开始实践 - .NET MVC服务器端

    上面我们可以让jquery来调用action了,那么我们接下来就来写这个action,并把结果以json的格式返回给jquery,具体代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    /// <summary>
    /// 返回文章列表
    /// </summary>
    /// <param name="name"></param>
    /// <returns></returns>
    [HttpPost]
    public ActionResult getArtical()
    {
    List<Artical> artList = new List<Artical>();
    artList.Add(new Artical(){ Id = 1,Title = "测试文章1" });
    artList.Add(new Artical(){ Id = 2,Title = "测试文章2" });
    return Json(artList); //MVC中可以用Json函数来将C#对象序列化成JSON对象
    }

    这个和以前普通的服务器代码不同的是最后我们可以非常方便地用Json函数将C#对象序列化成JSON对象并返回给jquery,代码十分简洁。

    四、总结

    在.NET MVC中使用jquery更加方便,jquery端只要我们指定返回的数据类型(datatype)为json就可以方便地使用服务器返回的json数据;服务器端我们可以用Json函数非常方便地将c#对象序列化成json对象而不必写一大堆的Response.Write("......")。本文到此结束!

  • 相关阅读:
    Ueditor使用以及遇到的问题
    自己写一个分页PageHelper
    C#_IO操作_查询指定文件夹下的每个子文件夹占空间的大小
    C#发邮件_EmailHelper
    位运算反(~)与(&)异或(^)或(|)右移(>>)左移(<<)
    shell命令快捷键
    Openstack Day1简介及虚拟环境搭建
    VirtualBox双网卡搭建Linux虚拟实验环境
    git 学习笔记
    python socket 网络编程
  • 原文地址:https://www.cnblogs.com/freeliver54/p/3140198.html
Copyright © 2020-2023  润新知