[转载]关于json的一点总结

[转载]关于json的一点总结 – 雨蛇竹子 – 博客园.

json一般用在少量的数据处理。因为格式简单,操作方便,而且JavaScript本事就支持json格式的处理功能。所以建议大家使用

json一般格式如下:{“id”:”1″,”name”:”abc”}或者[{“id”:”1″,”name”:”abc”},{“id”:”1″,”name”:”abc”}]

下面是js中几种解释json格式的方法:

1,eval(‘(‘+json+’)’)
为什么这样写:主要是因为在JavaScript中,表达式语句不允许以左花括号”{“开始,如果这样做,会与块语句产生混淆.在使用eval()解析JSON文本时,为了解决这个问题,就需要加上圆括号.圆括号作为分组运算符,可以对包围在其中的表达式求职.
2,var strJSON= (new Function(“return ” + json))();
通过创建方法的方式解释json
3,var strJSON= JSON.parse(json);
注意:这种方法能够解释的json格式必须键值对都要加双引号,不然解释不了json格式

实例
json.aspx页面:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="json.aspx.cs" Inherits="web.javascript.json.json" %>
 
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div id="div1">
    </div>
    <input type="button" id="btn" value="but" />
    </form>
 
    <script type="text/javascript" src="http://www.cnblogs.com/script/jquery-1.7.1.min.js"></script>
 
    <script type="text/javascript">
 
        // 异步处理json对象
 
        $("#btn").click(function() {
            $.ajax({
                url: "json.ashx",
                type: "post",
                data: { id: "123" },
                datatype: "json",
                success: function(data) {
                    var strData = data;
                    alert("1-----------");
                    var str1 = eval("(" + data + ")");  // 第一种js解释json
 
                    alert("2-----------");
                    var str2 = (new Function("return " + strData))();  // 第二种js解释json
                    alert(str2.id + "  @  " + str2.name);
 
                    alert("3-----------");
                    var str3 = JSON.parse(strData);
                    alert(str3.id + "  @  " + str3.name);
 
                    // 处理多维json
                    var strSs = "";
                    alert(str1.length);
                    for (var i = 0; i < str1.length; ++i) {
                        strSs += str1[i].id + "@" + str1[i].name + "\n";
                    }
                    alert(strSs);
                },
                error: function(xhr, data, ts) {
                    alert(data);
                }
            });
        });
    </script>
 
</body>
</html>

json.ashx处理程序

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
 
namespace web.javascript.json
{
    /// <summary>
    /// $codebehindclassname$ 的摘要说明
    /// </summary>
    [WebService(Namespace = "http://tempuri.org/")]
    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
    public class json1 : IHttpHandler
    {
 
        public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
 
            // 多维
            string strJSONs = "[{\"id\":1,\"name\":\"11\"},{\"id\":2,\"name\":\"22\"},{\"id\":3,\"name\":\"33\"}]";
            // 一维
            //string strJSONs={\"id\":\"123\",\"name\":\"qwe\"}
 
            context.Response.Write(strJSONs);
 
            context.Response.End();
        }
 
        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}

以上是本人在实际项目中的总结,希望对大家有帮助,同时也希望大家多多指点。

赞(0) 打赏
分享到: 更多 (0)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏