zoukankan      html  css  js  c++  java
  • js实现对json数据的序列化(兼容ie6以上浏览器)

    /**
     * 增加对JSON数据的序列化方法,
     * 主要用于IE6、7不支持JSON对象的浏览器
     */

    var xue = xue || {};
    xue.json = xue.json || {};

    xue.json.stringify = function(obj) {
        //如果是IE8+ 浏览器(ff,chrome,safari都支持JSON对象),使用JSON.stringify()来序列化
        if (window.JSON) {
            return JSON.stringify(obj);
        }
        var t = typeof(obj);
        if (t != "object" || obj === null) {
            // simple data type
            if (t == "string") obj = '"' + obj + '"';
            return String(obj);
        } else {
            // recurse array or object
            var n, v, json = [],
                arr = (obj && obj.constructor == Array);

            // fix.
            var self = arguments.callee;

            for (n in obj) {
                v = obj[n];
                t = typeof(v);
                if (obj.hasOwnProperty(n)) {
                    if (t == "string") v = '"' + v + '"';
                    else if (t == "object" && v !== null)
                    // v = jQuery.stringify(v);
                        v = self(v);
                    json.push((arr ? "" : '"' + n + '":') + String(v));
                }
            }
            return (arr ? "[" : "{") + String(json) + (arr ? "]" : "}");
        }
    };
    /*
     * method : parse(json string)
     * return : js原生值
     */
    xue.json.parse = function(jsonString) {
        if (window.JSON) {
            return window.JSON.parse(s);
        }
        //使用到了jquery的parseJSON(s)方法
        return $.parseJSON(jsonString);
    };

    使用方法:

    var _json = {

          "js_58":['a','b'],

          "js_39":['a','b','c'],

          "js_68":['a']

    }

    将json对象_json序列化:

      xue.json.stringify(_json);

    注意:如果ajax传参是json数据对象时,最好将json对象先序列化

  • 相关阅读:
    单片机 APROM: RAM: Flash:区别
    char (*a) [N]
    strcat的几种实现及性能比较
    sprintf用法
    void (*pFunction)(void);
    16个单片机常用模块电路
    MOS管工作原理
    STM32借用固件库使用外设的说明
    Python之并发编程(二)进程
    Python之并发编程(一)进程和操作系统概述
  • 原文地址:https://www.cnblogs.com/dearxinli/p/5524180.html
Copyright © 2011-2022 走看看