Skip to content

Latest commit

 

History

History
33 lines (25 loc) · 743 Bytes

README.md

File metadata and controls

33 lines (25 loc) · 743 Bytes

json-parse-safe

Like JSON.parse, but doesn't throw on invalid JSON.

Installation

npm i @ambassify/json-parse-safe

Usage

Takes the same arguments as JSON.parse.

const parse = require('json-parse-safe');
const validJson = '{ "foo": "bar" }';
const invalidJson = 'foo';

// Simple usage
console.log(parse(validJson)); // { foo: 'bar' }
console.log(parse(invalidJson)); // null

// Pass a reviver just like the real JSON.parse
parse('{"p": 5}', (key, value) =>
  typeof value === 'number'
    ? value * 2 // return value * 2 for numbers
    : value     // return everything else unchanged
);
// { p: 10 }

// choose a defaultValue for invalid json
console.log(parse(invalidJson, undefined, 'WHOOPS')); // 'WHOOPS'