我试图使用JSON解析器将检测并保存重复键。 我与齐磊,其中我希望会告诉我,当我得到一个重复键的node.js使用JSON.parse()来。 然而事实并非如此。 有另一种方式? 有它处理的齐磊或其他参数重复键更好的JSON解析器?
"use strict";
try {
var content = '{"value": "a", "value": "b", "value": "c" }';
console.log(content);
var parsed = JSON.parse(content, function(k, v) {
console.log(k+"="+JSON.stringify(v));
return v;
});
} catch (e) {
console.log(e);
}
输出是:
{"value": "a", "value": "b", "value": "c" }
value="c"
={"value":"c"}
JSON.parse()
解析字符串以同样的方式您是否提供齐磊功能 (换句话说,它没有切换到当一个“流解析器” reviver
传递中)。 提供一个reviver
功能仅仅是一个方便,以免有编写必要的自我循环。
有一些流JSON解析器上NPM,例如: 单簧管 , JSONStream和双簧管 。 下面是这3个一个小测试:
var clarinet = require('clarinet').parser();
var JSONStream = require('JSONStream').parse('*', function (value, path) {
return { key: path[path.length - 1], value: value, path: path }
});
var rs = new (require('stream').Readable)();
rs._read = function(n) {};
var oboe = require('oboe')(rs);
var content = '{"value": "a", "value": "b", "value": "c" }';
clarinet.onopenobject = clarinet.onkey = function(k) {
console.log('clarinet key =', k);
};
clarinet.onvalue = function(v) {
console.log('clarinet value =', v);
};
clarinet.write(content).close();
JSONStream.on('data', function(d) {
console.log('JSONStream data:', arguments);
}).end(content);
oboe.on('node:*', function(n) {
console.log('oboe node:', arguments);
});
rs.push(content);
rs.push(null);
// output:
// clarinet key = value
// clarinet value = a
// clarinet key = value
// clarinet value = b
// clarinet key = value
// clarinet value = c
// JSONStream data: { '0': { key: 'value', value: 'a', path: [ 'value' ] } }
// JSONStream data: { '0': { key: 'value', value: 'b', path: [ 'value' ] } }
// JSONStream data: { '0': { key: 'value', value: 'c', path: [ 'value' ] } }
// oboe node: { '0': 'a', '1': [ 'value' ], '2': [ { value: 'a' }, 'a' ] }
// oboe node: { '0': 'b', '1': [ 'value' ], '2': [ { value: 'b' }, 'b' ] }
// oboe node: { '0': 'c', '1': [ 'value' ], '2': [ { value: 'c' }, 'c' ] }
// oboe node: { '0': { value: 'c' }, '1': [], '2': [ { value: 'c' } ] }