来源 : http://javascript.ruanyifeng.com/stdlib/date.html
//解析json也可以传入一个方法, 基本上和stringify差不多,不过是逆序的, 要注意key = "" 的return ,基本上返回 value就好 //自己做一个test比较好理解 function f(key, value) { //console.log(key); //console.log(value); if (key === "") { return value; } return { age: 12 }; } var o1 = { name: "keatkeat", array: ["a", "b"] } var o = JSON.parse(JSON.stringify(o1), f); console.log(o); //第2个参数数组的话,可以针对obj 过滤出我们指定想要的属性 //第2参数是函数的话,会梯归执行坎套的对象和数组,返回undefined的话这个属性将被忽略 //这个 key value 循环包括 对象(key="",value=object),数组(key="",value=array),对象内的每一个属性(key=attr,value=value),数组中的每一个值(key=0, value=value) //return 的value 将继续被梯归下去,比如你把一个string 变成 return一个对象,它也会梯归处理这个对象 (所以要注意循环引用) //如果处理的是一个对象而且它拥有 toJSON 这个方法的话,那么将会调用它来获取return value (比如js Date就带有这个方法) //自己做一个test就容易理解了。 //第3个参数可以做美美的JSON JSON.stringify(obj, function (key, value) { console.log(key); console.log(value); //自定义处理的话,要顾虑到这个哦 if (value.toJSON) { return value.toJSON(); } return value; }, " "); JSON.stringify(obj, ["onlyThisAttrWant"], " ");