✨ Faster and safer JSON and JSONC minify, parse and stringify for JavaScript (Browser compatible) — 2.3KB.
Many JSON minification packages rely on vulnerable regex, making them unsuitable for production.
jsonc.min prioritizes security by avoiding these pitfalls and offering a robust solution.
jsonc.min ensures full compatibility with both Node.js, Bun, Deno and, browser environments.
All features work for both JSON and JSONC.
Zero dependencies and optimized for production environments.
# Node.js
npm i jsonc.min
# Bun
bun add jsonc.min
# Deno
deno add npm:jsonc.min
import { JSONC } from 'jsonc.min';
const { JSONC } = require('jsonc.min');
<script src="https://cdn.jsdelivr.net/npm/jsonc.min/browser/jsonc.min.js"></script>
Convert from JSONC to JSON.
JSONC.toJSON('/* JSONC content */ { "test": true }');
// "{ test: true }"
If the content is already JSON, it will just be preserved:
JSONC.toJSON('{ "test": true }');
// "{ test: true }"
Minify both JSON and JSONC.
const content = `
/**
* JSONC content
*/
{
"test": true // 🔬
}
`;
JSONC.minify(content);
// "{test:true}"
const content = `
{
"test": true
}
`;
JSONC.minify(content);
// "{test:true}"
Parse both JSON and JSONC.
const content = `
/**
* JSONC content
*/
{
"test": true // 🔬
}
`;
JSONC.parse(content);
// { test: true }
const content = `
{
"test": true
}
`;
JSONC.parse(content);
// { test: true }
- If your content is guaranteed to be a JSON, there is no advantage to using
JSONC.parse(content)
instead ofJSON.parse(content)
.
Prettify both JSON and JSONC.
Use
JSON.stringify
behind the scenes.
const content = '/** JSONC content */ { "test": true }';
JSONC.stringify(content, null, 2);
// "{
// "test": true
// }"
const content = '{ "test": true }';
JSONC.stringify(content, null, 2);
// "{
// "test": true
// }"
import { readFile } from 'node:fs/promises';
import { JSONC } from 'jsonc.min';
const content = await readFile('./file.jsonc', 'utf-8');
JSONC.parse(content);
For this example, let's assume a .configrc
that can be both a JSON or a JSONC, as well as looking for both config.json
and config.jsonc
files:
import { JSONC } from 'jsonc.min';
import { cwd } from 'node:process';
import { join } from 'node:path';
import { readFile } from 'node:fs/promises';
export const getConfigs = async (customPath?: string) => {
const targetRoot = cwd();
const expectedFiles = customPath
? [customPath]
: ['.configrc', 'config.json', 'config.jsonc'];
for (const file of expectedFiles) {
const filePath = join(targetRoot, file);
try {
const configsFile = await readFile(filePath, 'utf-8');
// jsonc.min will parse both JSON and JSONC extensions, even if there is no extension.
return JSONC.parse(configsFile);
} catch {}
return {};
}
};