JS对象序列化成json数据和json数据转化为JS对象的代码


Posted in Javascript onAugust 23, 2017

JS对象序列化成json数据:

function Serialize(obj){   
  switch(obj.constructor){   
    case Object:   
      var str = "{";   
      for(var o in obj){   
        str += o + ":" + Serialize(obj[o]) +",";   
      }   
      if(str.substr(str.length-1) == ",")   
        str = str.substr(0,str.length -1);   
       return str + "}";   
       break;   
     case Array:         
       var str = "[";   
       for(var o in obj){   
         str += Serialize(obj[o]) +",";   
       }   
       if(str.substr(str.length-1) == ",")   
         str = str.substr(0,str.length -1);   
       return str + "]";   
       break;   
     case Boolean:   
       return "\"" + obj.toString() + "\"";   
       break;   
     case Date:   
       return "\"" + obj.toString() + "\"";   
       break;   
     case Function:   
       break;   
     case Number:   
       return "\"" + obj.toString() + "\"";   
       break;    
     case String:   
       return "\"" + obj.toString() + "\"";   
       break;     
   }   
 }   
var staff_list_obj  ={};  
var staff_id   = 1001;  
staff_list_obj[staff_id]  = {};  
staff_list_obj[staff_id]["姓名"] = '111';  
staff_list_obj[staff_id]["测试"] = '222';  
alert(Serialize(staff_list_obj));

JS对象序列化为JSON对象的方法二

var $ = $ || {};



/** 
 * 将JS对象序列化为JSON字符串 
 * @param {Mixed} o The variable to decode 
 * @return {String} The JSON string 
 * String json = $.encode(o); 
 */ 
$.encode = (function() {
  if ( typeof(JSON)!=='undefined' && typeof(JSON.stringify)!=='undefined') {
    return JSON.stringify;
  }
  var I = !!{}.hasOwnProperty, _ = function(I) {
    return I < 10 ? "0" + I : I;
  }, A = {
    "\b" : "\\b",
    "\t" : "\\t",
    "\n" : "\\n",
    "\f" : "\\f",
    "\r" : "\\r",
    "\"" : "\\\"",
    "\\" : "\\\\"
  };
  return (function(C) {
    if (typeof C == "undefined" || C === null) {
      return "null";
    } else {
      if (Object.prototype.toString.call(C) === "[object Array]") {
        var B = ["["], G, E, D = C.length, F;
        for (E = 0; E < D; E += 1) {
          F = C[E];
          switch (typeof F) {
            case "undefined" :
            case "function" :
            case "unknown" :
              break;
            default :
              if (G) {
                B.push(",");
              }
              B.push(F === null ? "null" : $.encode(F));
              G = true;
          }
        }
        B.push("]");
        return B.join("");
      } else {
        if ((Object.prototype.toString.call(C) === "[object Date]")) {
          return "\"" + C.getFullYear() + "-" + _(C.getMonth() + 1) + "-" + _(C.getDate()) + "T" + _(C.getHours()) + ":" + _(C.getMinutes()) + ":" + _(C.getSeconds()) + "\"";
        } else {
          if (typeof C == "string") {
            return "\"" + C.replace(/([\x00-\x1f\\"])/g, function(B, _) {
              var I = A[_];
              if (I) {
                return I;
              }
              return '';
            }).replace(/[^\u0000-\u00FF]/g, function($0) {
              return escape($0).replace(/(%u)(\w{4})/gi, "\\u$2")
            }) + "\"";
          } else {
            if (typeof C == "number") {
              return isFinite(C) ? String(C) : "null";
            } else {
              if (typeof C == "boolean") {
                return String(C);
              } else {
                B = ["{"], G, E, F;
                for (E in C) {
                  if (!I || C.hasOwnProperty(E)) {
                    F = C[E];
                    if (F === null) {
                      continue;
                    }
                    switch (typeof F) {
                      case "undefined" :
                      case "function" :
                      case "unknown" :
                        break;
                      default :
                        if (G) {
                          B.push(",");
                        }
                        B.push($.encode(E), ":", $.encode(F));
                        G = true;
                    }
                  }
                }
                B.push("}");
                return B.join("");
              }
            }
          }
        }
      }
    }
  });
})();

json数据转化为JS对象:

var jsonString={....}/[....];
eval("var obj="+jsonString);
alert(obj);

写道

function evalJSON(json){ 
var obj = null; 
try { 
obj = eval("(" + json + ")"); 
} catch(E){} 

return obj ; 
}
Javascript 相关文章推荐
Jquery注册事件实现方法
May 18 Javascript
jQuery基于ajax实现带动画效果无刷新柱状图投票代码
Aug 10 Javascript
jquery使用ul模拟select实现表单美化的方法
Aug 18 Javascript
setTimeout学习小结
Feb 08 Javascript
vue父组件中获取子组件中的数据(实例讲解)
Sep 27 Javascript
图片加载完成再执行事件的实例
Nov 16 Javascript
js中的 || 与 &amp;&amp; 运算符详解
May 24 Javascript
微信小程序云开发之新手环境配置
May 16 Javascript
layui表格 返回的数据状态异常的解决方法
Sep 10 Javascript
解决layer.confirm选择完之后消息框不消失的问题
Sep 16 Javascript
微信小程序自定义模态弹窗组件详解
Dec 24 Javascript
JavaScript实现页面高亮操作提示和蒙板
Jan 04 Javascript
Angular 2 利用Router事件和Title实现动态页面标题的方法
Aug 23 #Javascript
angular2路由切换改变页面title的示例代码
Aug 23 #Javascript
通俗解释JavaScript正则表达式快速记忆
Aug 23 #Javascript
bootstrap fileinput实现文件上传功能
Aug 23 #Javascript
jQuery Position方法使用和兼容性
Aug 23 #jQuery
详解EasyUi控件中的Datagrid
Aug 23 #Javascript
Vue0.1的过滤代码如何添加到Vue2.0直接使用
Aug 23 #Javascript
You might like
php file_get_contents函数轻松采集html数据
2010/04/22 PHP
PHP6 中可能会出现的新特性预览
2014/04/04 PHP
php结合ajax实现赞、顶、踩功能实例
2014/05/12 PHP
Laravel框架表单验证操作实例分析
2019/09/30 PHP
js获取height和width的方法说明
2013/01/06 Javascript
javascript 实现字符串反转的三种方法
2013/11/23 Javascript
Javascript实现返回上一页面并刷新的小例子
2013/12/11 Javascript
详解JavaScript函数
2015/12/01 Javascript
jQuery插件uploadify实现ajax效果的图片上传
2016/06/18 Javascript
BootStrap的table表头固定tbody滚动的实例代码
2016/08/24 Javascript
javascript cookie基础应用之记录用户名的方法
2016/09/20 Javascript
基于BootstrapValidator的Form表单验证(24)
2016/12/12 Javascript
浅谈Nodejs中的作用域问题
2016/12/26 NodeJs
微信小程序 页面跳转传递值几种方法详解
2017/01/12 Javascript
less简单入门(CSS 预处理语言)
2017/03/08 Javascript
nodejs服务搭建教程 nodejs访问本地站点文件
2017/04/07 NodeJs
JavaScript编写的网页小游戏,很给力
2017/08/18 Javascript
nodejs微信扫码支付功能实现
2018/02/17 NodeJs
karma+webpack搭建vue单元测试环境的方法示例
2018/05/24 Javascript
vue.js 添加 fastclick的支持方法
2018/08/28 Javascript
详解使用React制作一个模态框
2019/03/14 Javascript
如何使用JavaScript实现栈与队列
2019/06/24 Javascript
[01:16:37]【全国守擂赛】第三周决赛 Dark Knight vs. 一个弱队
2020/05/04 DOTA
[03:40]DOTA2抗疫特别篇《英雄年代》
2020/02/28 DOTA
python3爬取淘宝信息代码分析
2018/02/10 Python
Ubuntu+python将nii图像保存成png格式
2019/07/18 Python
python 直接赋值和copy的区别详解
2019/08/07 Python
购买限量版收藏品、珠宝和礼品:Bradford Exchange
2016/09/23 全球购物
欧洲最大的球衣网上商店:Kitbag
2017/11/11 全球购物
马来西亚在线购物:POPLOOK.com
2019/12/09 全球购物
行政助理求职自荐信
2013/10/26 职场文书
汇源肾宝广告词
2014/03/20 职场文书
幼儿园端午节活动总结
2015/05/05 职场文书
义卖募捐活动总结
2015/05/09 职场文书
结婚典礼致辞
2015/07/28 职场文书
golang中实现给gif、png、jpeg图片添加文字水印
2021/04/26 Golang