首页 > 语言 > JavaScript > 正文

Node.js JSON模块用法实例分析

2024-05-06 15:43:32
字体:
来源:转载
供稿:网友

本文实例讲述了Node.js JSON模块用法。分享给大家供大家参考,具体如下:

一、JSON.stringify语法:

JSON.stringify(value [, replacer] [, space])

value:是必选字段。就是你输入的对象,比如数组,类等。

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

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

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

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

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

(2)如果是字符串或者是转义字符,则会在每一个键值对(”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]"'*/
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"'*/

二、JSON.parse语法:

JSON.parse(string)

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

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

PS:这里再为大家推荐几款相关的json在线工具供大家参考:

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选