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 相关文章推荐
js indexOf()定义和用法
Oct 21 Javascript
关于jQuery $.isNumeric vs. $.isNaN vs. isNaN
Apr 15 Javascript
使用javascript:将其它类型值转换成布尔类型值的解决方法详解
May 07 Javascript
JavaScript导出Excel实例详解
Nov 25 Javascript
最简单的JavaScript图片轮播代码(两种方法)
Dec 18 Javascript
概述javascript在Google IE中的调试技巧
Nov 24 Javascript
vue调用高德地图实例代码
Apr 28 Javascript
Angular.js中上传指令ng-upload的基本使用教程
Jul 30 Javascript
elementui的默认样式修改方法
Feb 23 Javascript
基于JQuery实现页面定时弹出广告
May 08 jQuery
JavaScript实现拖拽和缩放效果
Aug 24 Javascript
vue路由实现登录拦截
Mar 24 Vue.js
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 进程锁定问题分析研究
2009/11/24 PHP
CodeIgniter CLI模式简介
2014/06/17 PHP
ThinkPHP安装和设置
2015/07/27 PHP
JS事件在IE与FF中的区别详细解析
2013/11/20 Javascript
js实现卡片式项目管理界面UI设计效果
2015/12/08 Javascript
浅析JS运动
2015/12/28 Javascript
JavaScript获取键盘按键的键码(参照表)
2017/01/10 Javascript
js实现PC端根据IP定位当前城市地理位置
2017/02/22 Javascript
微信小程序中的swiper组件详解
2017/04/14 Javascript
JavaScript实现二维坐标点排序效果
2017/07/18 Javascript
浅谈Angular4中常用管道
2017/09/27 Javascript
webpack搭建vue 项目的步骤
2017/12/27 Javascript
Webpack 4.x搭建react开发环境的方法步骤
2018/08/15 Javascript
Vue中用props给data赋初始值遇到的问题解决
2018/11/27 Javascript
nodejs搭建本地服务器并访问文件操作示例
2019/05/11 NodeJs
javascript删除数组元素的七个方法示例
2019/09/09 Javascript
如何手写简易的 Vue Router
2020/10/10 Javascript
[01:12:27]EG vs Secret 2018国际邀请赛淘汰赛BO3 第二场 8.22
2018/08/23 DOTA
Web服务器框架 Tornado简介
2014/07/16 Python
python处理二进制数据的方法
2015/06/03 Python
详解如何使用Python编写vim插件
2017/11/28 Python
Python使用matplotlib简单绘图示例
2018/02/01 Python
python调用tcpdump抓包过滤的方法
2018/07/18 Python
详解Python读取yaml文件多层菜单
2019/03/23 Python
如何将你的应用迁移到Python3的三个步骤
2019/12/22 Python
tensorflow2.0与tensorflow1.0的性能区别介绍
2020/02/07 Python
python 如何引入协程和原理分析
2020/11/30 Python
简单掌握CSS3将文字描边及填充文字颜色的方法
2016/03/07 HTML / CSS
马来西亚最好的婴儿商店:Motherhood
2017/09/14 全球购物
美国林业供应商:Forestry Suppliers
2019/05/01 全球购物
Monki官网:斯堪的纳维亚的独立时尚品牌
2020/11/09 全球购物
一套SQL笔试题
2016/08/14 面试题
公司端午节活动方案
2014/02/04 职场文书
党员创先争优心得体会
2014/09/11 职场文书
综合素质评价思想道德自我评价
2015/03/09 职场文书
深入解析Apache Hudi内核文件标记机制
2022/03/31 Servers