• ASP.NET如何使用JSON


    关于json,有一个官网:http://www.json.org 上面介绍了每种语言生成json格式的类库,我们只要把他们下载解压之后调用他们其中的组件即可,在.net中我用的是Newtonsoft.Json.dll这个组件,这个组件有好几种版本,有1.0,3.5等等。关于他的用法可以到官网去具体了解一下,这样我这里主要是介绍我们如何用他们,首先要在后台处理页面生成并返回json数据格式,数据处理页面这里可以用aspx或者ashx页面,如果用aspx页面来处理的话,首页把aspx的源视图中除了第一行之外,其余行都要删除,因为如果不删除的话,那么他们都将被返回给前台调用者必定造成错误.下面我介绍如何用ashx页面来生成json并返回。下面建一个Handler.ashx页面,下面是它里面的代码在引用Newtonsoft.Json.dll,要先将Newtonsoft.Json.dll放在Bin文件中,然后再页面添加对他的引用using Newtonsoft.Json;

      IList<RoomCate> list = RoomCateManager.GetAllRoomCateInfo();
      string Content = JavaScriptConvert.SerializeObject(list);//将数据转成json格式
      Response.Write(Content ); //输出json

     从上面可以看出返回的是一个数组,里面包含许多的json对象,格式是[{"id":"1"},{"id":"2"}]

    RoomCate rc=RoomCateManager.GetRoomCateInfo(id);
    string Content = JavaScriptConvert.SerializeObject(rc);//将数据转成json格式
    Response.Write(Content ); //输出json

    上面输入的json格式为{"id":"1"}

    那么我们前台如何调用并解析它呢,这里我们要用jquery里面的ajax方法,当然用的前提是用引用jquery.js文件。这里我推荐用getJSON方法因为他直接就返回json的数据格式

     $.getJSON("Handler/Handler.ashx", function (json) {
                    $.each(json, function (index, array) { //解析json数组用的方法
                        var roomID= array['RoomID'];//RoomID用类的属性
                        $("#NewsTop").append(roomID);//把它加载到我们要显示他们的html标签中
                    });
      });

     

    如果返回是json对象格式为{"id":"1"}那么我们将如何解析它呢,使用方法一样只是解析方法不一样

     $.getJSON("Handler.ashx", function (json) {//直接用json.属性即可
                  $("#logo").append("<img src='../SystemFiles/" + json.PictureName + "' width='234' height='172' />");
                  $("#intro").html(json.Contents.substr(0, 420) + "...");
    });

     

    如果要交给aspx页面处理的话,不仅用将源代码中只保留第一行,其余行删除之外,还有加随机数

    $.getJSON("Handler.aspx", {sjd: Date().toLocaleString() }, function (json) {

     .....................//解析方法同上,其中data参数为sjd: Date().toLocaleString() ,这句就是随机数确保每次解析都不一样
     });

  • 相关阅读:
    双重标准,我该怎么解决
    今天突然点开一个网页
    反省
    (无)
    (无)
    GetModuleHandleW 分析
    关于逆向360相关的一点感想
    OpenGL的编译和使用
    360 补天平台,也没个什么人啊。。。
    openssl编译方法
  • 原文地址:https://www.cnblogs.com/PearlRan/p/4833041.html
Copyright © 2020-2023  润新知