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实现预览待上传的本地图片
Mar 15 Javascript
js事件(Event)知识整理
Oct 11 Javascript
xmlhttp缓存清除的2种解决方法
Dec 13 Javascript
纯HTML5制作围住神经猫游戏-附源码下载
Aug 23 Javascript
HTML5 Shiv完美解决IE(IE6/IE7/IE8)不兼容HTML5标签的方法
Nov 25 Javascript
基于jQuery1.9版本如何判断浏览器版本类型
Jan 12 Javascript
基于JS模仿windows文件按名称排序效果
Jun 29 Javascript
jQuery自适应轮播图插件Swiper用法示例
Aug 24 Javascript
基于JavaScript实现的折半查找算法示例
Apr 14 Javascript
JS实现520 表白简单代码
May 21 Javascript
vue-openlayers实现地图坐标弹框效果
Sep 24 Javascript
JavaScript实现拖动对话框效果的实现代码
Oct 12 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 array_push()数组函数:将一个或多个单元压入数组的末尾(入栈)
2011/07/12 PHP
PHP 利用Mail_MimeDecode类提取邮件信息示例
2014/01/26 PHP
php利用事务处理转账问题
2015/04/22 PHP
PHP和C#可共用的可逆加密算法详解
2015/10/26 PHP
CentOS7.0下安装PHP5.6.30服务的教程详解
2018/09/29 PHP
List Installed Hot Fixes
2007/06/12 Javascript
html中使用javascript调用本地程序(exe、doc等)实现代码
2013/04/26 Javascript
javascript unicode与GBK2312(中文)编码转换方法
2013/11/14 Javascript
手机端页面rem宽度自适应脚本
2015/05/20 Javascript
javascript多物体运动实现方法分析
2016/01/08 Javascript
js实现弹窗居中的简单实例
2016/10/09 Javascript
html判断当前页面是否在iframe中的实例
2016/11/30 Javascript
vue实现表格数据的增删改查
2017/07/10 Javascript
让你彻底掌握es6 Promise的八段代码
2017/07/26 Javascript
AngularJS 仿微信图片手势缩放的实例
2017/09/28 Javascript
vue实现图书管理demo详解
2017/10/17 Javascript
Bootstrap标签页(Tab)插件切换echarts不显示问题的解决
2018/07/13 Javascript
详解vue-cli@2.x项目迁移日志
2019/06/06 Javascript
vue data对象重新赋值无效(未更改)的解决方式
2020/07/24 Javascript
JS实现斐波那契数列的五种方式(小结)
2020/09/09 Javascript
Python浅复制中对象生存周期实例分析
2018/04/02 Python
Python走楼梯问题解决方法示例
2018/07/25 Python
Python基于mysql实现学生管理系统
2019/02/21 Python
python实现大文本文件分割
2019/07/22 Python
CSS3制作ajax loader icon实现思路及代码
2013/08/25 HTML / CSS
荷兰皇家航空公司官方网站:KLM Royal Dutch Airlines
2017/12/07 全球购物
获取邓白氏信用报告:Dun & Bradstreet
2019/01/22 全球购物
最新远光软件笔试题面试题内容
2013/11/08 面试题
CSMA/CD介质访问控制协议
2015/11/17 面试题
个人简历的自荐信
2013/10/23 职场文书
简历上的自我评价
2014/02/03 职场文书
学校领导干部民主生活会整改方案
2014/09/29 职场文书
2015年组织部工作总结
2015/04/03 职场文书
使用HTML+Css+transform实现3D导航栏的示例代码
2021/03/31 HTML / CSS
MySQL命令行操作时的编码问题详解
2021/04/14 MySQL
Redis sentinel哨兵集群的实现步骤
2022/07/15 Redis