作家
登录

JavaScript 序列化对象实现代码

作者: 来源:www.28hudong.com 2013-03-30 02:02:06 阅读 我要评论

作者发的是一张图,大家可以放大看。前些天说过关于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执行一下,就得到类实例了。

  推荐阅读

  用js实现层随着内容大小动态渐变改变 推荐

下面我们就自己来实现一个这样的组件,没有参考其他资料,纯属自己瞎写。 我觉得我这个方法很简单了,只需要在外边多套一个层就可以,而且可以容纳大量的文字(为什么这样说?因为如果只是单纯的图片,那调整起来简>>>详细阅读


本文标题:JavaScript 序列化对象实现代码

地址:http://www.17bianji.com/kaifa2/JS/27447.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)