zoukankan      html  css  js  c++  java
  • json格式的字符串序列化和反序列化的一些高级用法

    (1) 仅仅将指定属性对应的值序列化成字符串:

    var filter = {name: 'Jerry', sex: 'male', age: '10'};
    var jsonStr4 = JSON.stringify(filter, ['name']);
    console.log(jsonStr4); 
    

    想参与序列化的参数名通过JSON.stringify方法的第二个参数传入。

    上面例子中,只有name字段及对应的值参与了序列化,输出如下:

    (2) 序列化时,还可以编写函数,实现自定义序列化逻辑:

    var obj = {name: 'Jerry', sex: 'male', age: '40'};
    var jsonStr5 = JSON.stringify(obj, function(key, value) {
      if(key === 'name') {
        return 'my name is: ' + value;
      }
      else if( key === 'sex'){
      		// do not return, discard this attribute
      }
      else
      	return value;
    });
    

    输出:

    name属性的值通过自定义函数实现,前面加上了前缀。sex属性被丢弃,age属性保持不变。

    (3) 序列化时增加缩进,让输出的字符串更便于阅读

    var obj6 = {name: 'Jerry', sex: 'male', age: '40'};
    var jsonStr6 = JSON.stringify(obj6, null, 5);
    console.log(jsonStr6);  
    

    输出:

    要获取更多Jerry的原创文章,请关注公众号"汪子熙":

  • 相关阅读:
    开源TinyXML 最简单的新手教程
    2014第14周一开发问题记
    2014第13周日
    140329
    2014第13周五
    2014第13周四Webservice概念问题记
    2014第13周三
    2014第13周二
    2014第13周一
    2014第12周日
  • 原文地址:https://www.cnblogs.com/sap-jerry/p/12418561.html
Copyright © 2011-2022 走看看