Node.js JSON模块

举报
福州司马懿 发表于 2021/11/19 03:39:36 2021/11/19
【摘要】 一、JSON.stringify语法: JSON.stringify(value [, replacer] [, space]) 1 value:是必选字段。就是你输入的对象,比如数组,类等。repl...

一、JSON.stringify语法:

JSON.stringify(value [, replacer] [, space]) 
  
 
  • 1
  • value:是必选字段。就是你输入的对象,比如数组,类等。

  • replacer(可选参数):它又分为2种方式,一种是数组,第二种是方法。

    (1)replacer为数组时,表示的是Key,只有在中有出现过的Key的键值对(Key-Value)才会在转化的结果中出现。
    replacer数组仅对输入参数是类的情况有效,如果输入参数是数组则直接忽略该参数。

    (2)replacer为方法时,表示把每一个“键值对”作为参数送入函数中,然后用处理后的Value值替代原Value值输出到转化的结果中。
    replacer为方法仅对输入参数是数组的情况有效,如果输入参数是类则直接忽略该参数。

  • space(可选参数):就是用什么来做分隔符的。

    (1)如果省略的话,那么在每个键值对(”Key”:Value)就没有分隔符,否则会默认添加一个换行符 ‘\n’ 加上该分隔符。

    (3)如果是字符串或者是转义字符,则会在每一个键值对(”Key”:Value)添加上换行符 ‘\n’(包括第一个键值对),然后再加上该分隔符。

var person = new Object();
person.name = 'chy';
person.age = 24;
person.city= ['FuZhou', 'XiaMen'];
var replacerArr = [ 'name', 'city', 'unknown' ];
var space = '-*-';

JSON.stringify(person);
//输出 '{"name":"city","age":24,"city":["FuZhou","XiaMen"]}'
JSON.stringify(person, replacerArr);
//输出 '{"name":"chy","city":["FuZhou","XiaMen"]}'
JSON.stringify(person, function(key, value) {
    console.log("key = " + key);
    return value.toString().toUpperCase();
});
/*
输出
key =  
'"[OBJECT OBJECT]"'
*/
  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
var personArr = [ 'Bob', 'Tina', 'Tom', 'bob', 'Linda' ];
var replacerArr = [ 'name', 'city', 'unknown' ];
var space = '-*-';

JSON.stringify(personArr);
//输出 '["Bob","Tina","Tom","bob","Linda"]'
JSON.stringify(personArr, replacerArr);
//输出 '["Bob","Tina","Tom","bob","Linda"]'
JSON.stringify(personArr, function(key, value) {
    console.log("key = " + key);
    return value.toString().toUpperCase();
});
/*
输出
key =
'"BOB, TINA, TOM, BOB, LINDA"'
*/
  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

二、JSON.parse语法:

JSON.parse(string) 
  
 
  • 1

待解析的字符串无论是键还是值,都必须用”双引号”括起来。注意是双引号,单引号无效。

JSON.parse('{name:"chy"}');
//输出 SyntaxError: Unexpected token n in JSON at position 1

JSON.parse("{'name':'chy'}");
//输出 SyntaxError: Unexpected token ' in JSON at position 1

JSON.parse('{"name":"bob"}');
//输出 { name: 'bob' }

JSON.parse("{\"name\":\"bob\"}");
//输出 { name: 'bob' }

JSON.parse('{"age":1}');
//输出 { age: 1 }
  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

文章来源: blog.csdn.net,作者:福州-司马懿,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/chy555chy/article/details/52552548

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

举报
请填写举报理由
0/200