在实际网络环境中,我们经常将一组属性打包成一个类,然后将这个类序列化,传输到对端,对端接受到之后将其反序列化得到类。序列化的方法如下所示:
这样做有个问题,序列化和反序列化会导致类的方法被丢弃,得到的仅仅有属性。
我在网上百度了一下,基本没有什么好的解决方法,因此我采用的方法很暴力:再创建一个 Rectangle 类,把新对象的属性改为反序列化得到的值。
本来想用构造函数重载的,但是 node.js 不支持构造函数重载,行8...c++把我惯坏了。
早期的JSON解析器基本上就是使用JavaScript的eval()函数。由于JSON是JavaScript语法的自己,因此eval()函数可以解析、解释并返回JavaScript的对象和数组。ECMAScript
5对解析JSON的行为进行了规范,定义了全局对象JSON。
JSON对象有两个方法:stringify()和parse()。在最简单的情况下,这两个方法分别用于把JavaScript对象序列化为JSON字符串和把JSON字符串解析为原生JavaScript。例如:
新建一个HTML:代码如下:
复制代码
代码如下:
<html>
<head>
<title></title>
<script
type="text/javascript">
function
init()
{
var
book={
title:"JavaScript高级程序设计",
authors:[
"Nicholas
C.
Zakas"
],
edition:3,
year:2011
}
var
jsonBook=JSON.stringify(book)
var
objectBook=JSON.parse(jsonBook)
var
title=objectBook.title}
</script>
</head>
<body>
<input
type="button"
onclick="init()"
value="测试"
/>
</body>
</html>
默认情况下,JSON.stringify()输出的JSON字符串不包含任何空字符或缩进,因此保存在jsonBook中的字符串如下所示:
复制代码
代码如下:
{"title":"JavaScript高级程序设计","authors":["Nicholas
C.
Zakas"],"edition":3,"year":2011}
在序列化JavaScript对象时,所有函数及原型成员都会被有意忽略,不体现在结果中。此外,值为undefined的任何属性也都会被跳过。结果中最终都是值为有效JSON数据类型的实例属性。
注意,虽然book与objectBook具有相同的属性,但它们是两个独立的、没有任何关系的对象。如果传给JSON.parse()的字符串不是有效的JSON,该方法会抛出错误。
1、for in 循环
eg:var obj = {}
var b = function () {
for (var key in obj) {
return false
}
return true
}
console.log(b()) // true
2、对象序列化(将对象转换为字符串)后进行判断
eg:var data = {}
var b = (JSON.stringify(data) == "{}")
console.log(b) // true
3、jquery的isEmptyObject()方法
eg: var data = {}
var b = $.isEmptyObject(data)
console.log(b) // true
4、Object.getOwnPropertyNames()方法
eg: var data = {}
var arr = Object.getOwnPropertyNames(data)
console.log(arr.length == 0) // true
5、ES6中的Object.keys()方法
eg: var data = {}
var arr = Object.keys(data)
console.log(arr.length == 0) // true