天天看點

JavaScript對象也玩序列化和反序列化

JavaScript對象也玩序列化和反序列化

Object.prototype.Serialize = function()

JavaScript對象也玩序列化和反序列化

{

JavaScript對象也玩序列化和反序列化

    var type = __typeof__(this);

JavaScript對象也玩序列化和反序列化

    switch(type)

JavaScript對象也玩序列化和反序列化

    {

JavaScript對象也玩序列化和反序列化

         case 'Array' :

JavaScript對象也玩序列化和反序列化

         {

JavaScript對象也玩序列化和反序列化

              var strArray = '['; 

JavaScript對象也玩序列化和反序列化

              for ( var i=0 ; i < this.length ; ++i )

JavaScript對象也玩序列化和反序列化

              {

JavaScript對象也玩序列化和反序列化

                   var value = ''; 

JavaScript對象也玩序列化和反序列化

                   if ( this[i] )

JavaScript對象也玩序列化和反序列化

                   {

JavaScript對象也玩序列化和反序列化

                        value = this[i].Serialize();

JavaScript對象也玩序列化和反序列化

                   }

JavaScript對象也玩序列化和反序列化

                   strArray += value + ',';

JavaScript對象也玩序列化和反序列化

              }

JavaScript對象也玩序列化和反序列化

              if ( strArray.charAt(strArray.length-1) == ',' )

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

                   strArray = strArray.substr(0, strArray.length-1);

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

              strArray += ']';  

JavaScript對象也玩序列化和反序列化

              return strArray;

JavaScript對象也玩序列化和反序列化

         }

JavaScript對象也玩序列化和反序列化

         case 'Date' :

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

              return 'new Date(' + this.getTime() + ')';

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

         case 'Boolean' :

JavaScript對象也玩序列化和反序列化

         case 'Function' :

JavaScript對象也玩序列化和反序列化

         case 'Number' :

JavaScript對象也玩序列化和反序列化

         case 'String' :

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

              return this.toString();

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

         default :

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

              var serialize = '{'; 

JavaScript對象也玩序列化和反序列化

              for ( var key in this )

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

                   if ( key == 'Serialize' ) continue; 

JavaScript對象也玩序列化和反序列化

                   var subserialize = 'null';

JavaScript對象也玩序列化和反序列化

                   if ( this[key] != undefined )

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

                        subserialize = this[key].Serialize();

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

                   serialize += '\r\n' + key + ' : ' + subserialize + ',';

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

              if ( serialize.charAt(serialize.length-1) == ',' )

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

                   serialize = serialize.substr(0, serialize.length-1);

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

              serialize += '\r\n}';

JavaScript對象也玩序列化和反序列化

              return serialize;

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

    }

JavaScript對象也玩序列化和反序列化

};

    其實就是Array和Object的屬性比較的麻煩,需要遞歸的做這個Serialize操作。不過需要注意,Serialize方法就不需要被序列化出來了。下面是測試示例,不過這個序列化方法沒有對環狀引用做檢查,能序列化的對象很有限。

JavaScript對象也玩序列化和反序列化

var obj1 = []; 

JavaScript對象也玩序列化和反序列化

alert(obj1.Serialize());

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

var obj2 = [1,[2,[3,[4,[5,[6,[7,[8,[9,[0]]]]]]]]]];

JavaScript對象也玩序列化和反序列化

alert(obj2.Serialize());

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

var obj3 = 

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

         Properties1 : 1, Properties2 : '2', Properties3 : [3],

JavaScript對象也玩序列化和反序列化

         Method1 : function(){ return this.Properties1 + this.Properties3[0];},

JavaScript對象也玩序列化和反序列化

         Method2 : function(){ return this.Preperties2; }

JavaScript對象也玩序列化和反序列化

    };

JavaScript對象也玩序列化和反序列化

alert(obj3.Serialize());  

JavaScript對象也玩序列化和反序列化
JavaScript對象也玩序列化和反序列化

var obj4 = [null, 1, 'string', true, function(){return 'keke';}, new Object()];

JavaScript對象也玩序列化和反序列化

alert(obj4.Serialize());

    至于反序列化就非常的容易了,把上面的序列化結果用eval執行一下,就得到類執行個體了。

本文轉自部落格園鳥食軒的部落格,原文連結:http://www.cnblogs.com/birdshome/,如需轉載請自行聯系原部落客。

繼續閱讀