添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
JSON 基础教程
  • JSON 实例
  • 关于 JSON
  • JSON 教程
  • JSON 基础
  • json格式
  • JSON 示例
  • JSON解析
  • JSON遍历
  • JSON调用
  • JSON转换
  • JSON获取
  • JSON字符串
  • JSON数组

  • $.parse json ( jsonstr ); //jQuery.parseJSON(jsonstr),可以将json字符串转换成json对象


    2>浏览器支持的转换方式 (Firefox, chrome ,opera,safari,ie9,ie8)等浏览器:
    代码如下:

    JSON.parse(jsonstr); //可以将json字符串转换成json对象
    JSON.stringify(jsonobj); //可以将json对象转换成json对符串

    注:ie8(兼容模式),ie7和ie6没有JSON对象,推荐采用JSON官方的方式,引入json.js。

    3>Javascript支持的转换方式
    eval('(' + jsonstr + ')'); //可以将json字符串转换成json对象,注意需要在json字符外包裹一对小括号
    注:ie8(兼容模式),ie7和ie6也可以使用eval()将字符串转为JSON对象,但不推荐这些方式,这种方式不安全eval会执行json串中的表达式。

    4>JSON官方的转换方式
    Http ://www.json.org/提供了一个json.js,这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;

    可以在https:// git hub.com/douglascrockford/JSON-js上获取到这个js,一般现在用json2.js。

    在开发的过程中,如果对于少量参数的前后台传递,可以直接采用ajax的data函数,按json格式传递,后台Request即可,但有的时候,需要传递多个参数,这样后台

    接受的时候Request多个很麻烦,此时要按照类的格式或者 集合的形式进行传递。


    例如:前台按类的格式传递JSON对象:

    var jsonUserInfo = "{\"TUserName\":\"" + userName + "\",\"TInterest\":\"" + interest + "\",\"TSex\":\"" + sex + "\",\"TCity\":\"" + city + "\",\"TDetail\":\"" + detail + "\"}";

    如拼出的jsonUserInfo 无转义符号,需要var jsonArrayFinal = JSON.stringify(jsonArray);进行转换后再传递。

    代码如下:

    $.ajax(
    {
    type: "post",
    url: "ReceiveHandler1.ashx",
    data: { userInfo: jsonUserInfo, flag: "123456", key: "654321" },
    dataType: "text",
    success: function(data) {
    $("#divShow"). HTML (data);
    }
    });

    如果前台传递多个类格式的JSON数组,也就是集合类型:


    [{"name":"a"},{"name","b"},{"name","c"}],则无法传递,此时必须使用JSON.stringify将数组对象转换成字符串,再进行AJAX传递即可。

    比如我有两个变量,我要将a转换成字符串,将b转换成JSON对象:

    var a={"name":"tom","sex":"男","age":"24"};
    var b='{"name":"Mike","sex":"女","age":"29"}';

    在Firefox,chrome,opera,safari,ie9,ie8等高级浏览器直接可以用JSON对象的stringify()和parse()方法。

    JSON.stringify(obj)将JSON转为字符串。JSON.parse(string)将字符串转为JSON格式;

    上面的转换可以这么写:
    var a={"name":"tom","sex":"男","age":"24"};
    var b='{"name":"Mike","sex":"女","age":"29"}';
    var aToStr=JSON.stringify(a);
    var bToObj=JSON.parse(b);
    alert(typeof(aToStr));  //string
    alert(typeof(bToObj));//object

    JSON.stringify()

    ie8(兼容模式),ie7和ie6没有JSON对象,不过http://www.json.org/js.html提供了一个json.js,这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;你可以在https://github.com/douglascrockford/JSON-js上获取到这个js,一般现在用json2.js。

    ie8(兼容模式),ie7和ie6可以使用eval()将字符串转为JSON对象,

    var c='{"name":"Mike","sex":"女","age":"29"}';
    var cToObj=eval("("+c+")");
    alert(typeof(cToObj));

    jQuery中也有将字符串转为JSON格式的方法jQuery.parseJSON( json ),接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)对象。当然如果有兴趣可以自己封装一个jQuery扩展,jQuery.stringifyJSON(obj)将JSON转为字符串。