千家信息网

json格式的字符串序列化和反序列化的高级用法是什么

发表于:2024-09-22 作者:千家信息网编辑
千家信息网最后更新 2024年09月22日,json格式的字符串序列化和反序列化的高级用法是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。(1) 仅仅将指定属性
千家信息网最后更新 2024年09月22日json格式的字符串序列化和反序列化的高级用法是什么

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);

输出:

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。

0