JavaScript 序列化对象实现代码
JavaScript 序列化对象实现代码
发布时间:2016-12-30 来源:查字典编辑
摘要:作者发的是一张图,大家可以放大看。前些天说过关于JavaScript的LiteralSyntax问题,觉得挺有意思的,于是又研究了一下,能不...

JavaScript 序列化对象实现代码1

作者发的是一张图,大家可以放大看。

前些天说过关于JavaScript的Literal Syntax问题,觉得挺有意思的,于是又研究了一下,能不能把对象再转化为Literal形式呢?就像我们平时说的序列化和反序列化啥的。当然可以了,因为JavaScript对象自身都提供了一个toString()方法,默认就是返回简单对象的Literal形式。

我们需要作的就是判断对象的具体类型,然后分别Serialize每种对象,再输出为Object的Literal语法形式就行了。准确的判断对象类型,使用我曾经说过的__typeof__方法就行了,序列化对象实例的代码如下:

复制代码 代码如下:

Object.prototype.Serialize = function()

{

var type = __typeof__(this);

switch(type)

{

case 'Array' :

{

var strArray = '[';

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

{

var value = '';

if ( this[i] )

{

value = this[i].Serialize();

}

strArray += value + ',';

}

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

{

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

}

strArray += ']';

return strArray;

}

case 'Date' :

{

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

}

case 'Boolean' :

case 'Function' :

case 'Number' :

case 'String' :

{

return this.toString();

}

default :

{

var serialize = '{';

for ( var key in this )

{

if ( key == 'Serialize' ) continue;

var subserialize = 'null';

if ( this[key] != undefined )

{

subserialize = this[key].Serialize();

}

serialize += 'rn' + key + ' : ' + subserialize + ',';

}

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

{

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

}

serialize += 'rn}';

return serialize;

}

}

};

其实就是Array和Object的属性比较的麻烦,需要递归的做这个Serialize操作。不过需要注意,Serialize方法就不需要被序列化出来了。下面是测试示例,不过这个序列化方法没有对环状引用做检查,能序列化的对象很有限。

复制代码 代码如下:

var obj1 = [];

alert(obj1.Serialize());

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

alert(obj2.Serialize());

var obj3 =

{

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

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

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

};

alert(obj3.Serialize());

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

alert(obj4.Serialize());

至于反序列化就非常的容易了,把上面的序列化结果用eval执行一下,就得到类实例了。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类