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截取字符串实例详解
Nov 24 Javascript
关于JSON.parse(),JSON.stringify(),jQuery.parseJSON()的用法
Jun 30 Javascript
AngularJS实现一次监听多个值发生的变化
Aug 31 Javascript
JS实现旋转木马式图片轮播效果
Jan 18 Javascript
JS基于正则实现数字千分位用逗号分隔的方法
Jun 16 Javascript
解决在vue项目中webpack打包后字体不生效的问题
Sep 01 Javascript
基于Vue-cli快速搭建项目的完整步骤
Nov 03 Javascript
Angular事件之不同组件间传递数据的方法
Nov 15 Javascript
微信小程序与webview交互实现支付功能
Jun 07 Javascript
vue弹出框组件封装实例代码
Oct 31 Javascript
webpack.DefinePlugin与cross-env区别详解
Feb 23 Javascript
浅谈JavaScript中this的指向问题
Jul 28 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函数)
2006/10/09 PHP
php部分常见问题总结
2008/03/27 PHP
采用ThinkPHP中F方法实现快速缓存实例
2014/06/13 PHP
PHP第三方登录―QQ登录实现方法
2017/02/06 PHP
网站如何做到完全不需要jQuery也可以满足简单需求
2013/06/27 Javascript
JavaScript实现的日期控件具体代码
2013/11/18 Javascript
js截取中英文字符串、标点符号无乱码示例解读
2014/04/17 Javascript
Javascript 实现复制(Copy)动作方法大全
2014/06/20 Javascript
提交按钮的name='submit'引起的js失效问题及原因
2015/02/25 Javascript
php register_shutdown_function函数详解
2017/07/23 Javascript
JS遍历DOM文档树的方法实例详解
2018/04/03 Javascript
使用vue2.6实现抖音【时间轮盘】屏保效果附源码
2019/04/24 Javascript
了解JavaScript表单操作和表单域
2019/05/27 Javascript
js逆向解密之网络爬虫
2019/05/30 Javascript
JS动态显示倒计时效果
2019/12/12 Javascript
jQuery 选择器用法基础入门示例
2020/01/04 jQuery
django轻松使用富文本编辑器CKEditor的方法
2017/03/30 Python
Python实现定期检查源目录与备份目录的差异并进行备份功能示例
2019/02/27 Python
Python any()函数的使用方法
2019/10/28 Python
Python之指数与E记法的区别详解
2019/11/21 Python
From CSV to SQLite3 by python 导入csv到sqlite实例
2020/02/14 Python
Python函数生成器原理及使用详解
2020/03/12 Python
canvas实现飞机打怪兽射击小游戏的示例代码
2018/07/09 HTML / CSS
HTML5 Canvas——用路径描画线条实例介绍
2013/06/09 HTML / CSS
moosejaw旗下的户外商品促销网站:Mountain Steals
2017/02/27 全球购物
linux下进程间通信的方式
2014/12/23 面试题
机械专业应届生求职信
2013/12/12 职场文书
音乐教学反思
2014/02/02 职场文书
《乞巧》教学反思
2014/02/27 职场文书
养生餐厅创业计划书范文
2014/03/26 职场文书
产假请假条
2014/04/10 职场文书
校运动会广播稿(100篇)
2014/09/12 职场文书
医德医风自我评价
2014/09/19 职场文书
2015年材料员工作总结
2015/04/30 职场文书
OpenCV-Python实现人脸磨皮算法
2021/06/07 Python
Win11显卡控制面板打开显卡设置方法
2022/04/20 数码科技