JSON

cirplan的个人空间

字号+ 作者:H5之家 来源:H5之家 2015-09-20 11:59 我要评论( )

js原生JSON学习笔记:json 是一种数据格式,不是编程语言 json不支持undefined json字符串必须用双引...


    json不支持undefined
    json字符串必须用双引号
    json 对象要给属性加引号
    没有末尾分号

    json数组没有变量和分号

var person = { name : 'zhangsan', age : '29', school : { name : 'xiaoxue', location : 'shenzhen' } }; var personJson = JSON.stringify(person); // "{"name":"zhangsan","age":"29","school":{"name":"xiaoxue","location":"shenzhen"}}" JSON.parse(personJson); //Object {name: "zhangsan", age: "29", school: Object} JSON.stringify-接收两个参数,第一个是过滤器,为数组 or 函数; 第二个是缩进量; var person = { name : 'zhangsan', age : '29', school : { name : 'xiaoxue', location : 'shenzhen' } }; JSON.stringify(person,['name','age']); //"{"name":"zhangsan","age":"29"}" key--属性名;value--属性值 JSON.stringify( person, function( key, value ){ switch( key ){ case "name" : return value + ' man'; default : return value; } });//"{"name":"zhangsan man","age":"29","school":{"name":"xiaoxue man","location":"shenzhen"}}" 通过设置undefined 删除属性
JSON.stringify( person, function( key, value ){ if( key == 'name' ) return undefined; else return value; });//"{"age":"29","school":{"location":"shenzhen"}}" 字符串缩进 最多10,若为字符最多十个字符
JSON.stringify( person, null, 4); // "{ // "name": "zhangsan", // "age": "29", // "school": { // "name": "xiaoxue", // "location": "shenzhen" // } // }" JSON.stringify( person, null, "--"); // "{ // --"name": "zhangsan", // --"age": "29", // --"school": { // ----"name": "xiaoxue", // ----"location": "shenzhen" // --} // }" toJSON方法 可以为任何对象添加toJSON()方法
原生Date对象有toJSON()方法,返回ISO 8601日期字符串  与 toISOString()结果一样 var day = new Date(); day.toJSON(); //"2013-05-26T12:42:24.619Z" var person = { name : 'zhangsan', age : '29', school : { name : 'xiaoxue', location : 'shenzhen' }, toJSON : function(){ return this.name; } }; JSON.stringify( person ); //""zhangsan"" 序列化顺序
1.存在toJSON(),调用,否则,按顺序序列化;
 2.如果提供第二个参数,对第一步返回的结果过滤;
 3.对第二步的结果序列化;
4.如果存在三个参数,相应格式化;

还原函数

var personJson = JSON.stringify(person); JSON.parse(personJson, function( key, value ){ if( key == "name" ) return value + ' back'; else return value; }); //Object {name: "zhangsan back", age: "29", school: Object}
原生JSON支持的浏览器为 IE8+、Firefox 3.5+ 、Safari 4+、Opera 10.5 and Chrome


 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • 轻风love的个人空间

    轻风love的个人空间

    2015-10-31 19:39

网友点评
=