Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/callumlocke/json-formatter
Makes JSON easy to read.
https://github.com/callumlocke/json-formatter
Last synced: 3 days ago
JSON representation
Makes JSON easy to read.
- Host: GitHub
- URL: https://github.com/callumlocke/json-formatter
- Owner: callumlocke
- License: bsd-3-clause
- Created: 2012-08-05T15:13:03.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2024-05-09T19:23:59.000Z (8 months ago)
- Last Synced: 2025-01-09T13:26:23.780Z (10 days ago)
- Language: TypeScript
- Homepage: https://chrome.google.com/webstore/detail/json-formatter/bcjindcccaagfpapjjmafapmmgkkhgoa?hl=en
- Size: 175 KB
- Stars: 3,846
- Watchers: 95
- Forks: 882
- Open Issues: 151
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome - callumlocke/json-formatter - Makes JSON easy to read. (TypeScript)
- awesome - json-formatter - Makes JSON/JSONP easy to read. (JavaScript)
- favorite-link - 使 JSON / JSONP 易于阅读。
- chrome-extensions - JSON formatter - Makes JSON/JSONP easy to read. (Developer)
- awesome-ubuntu - Json Formatter
README
# JSON Formatter - the original
Chrome extension that auto-formats JSON when you view it in a browser tab.
## Features
- **Fast**, even on very long JSON pages
- Dark mode
- Syntax highlighting
- Collapsible trees, with indent guides
- Clickable URLs
- Negligible performance impact on non-JSON pages (less than 1 millisecond)
- Works on any valid JSON page – URL doesn't matter
- Buttons for toggling between raw and parsed JSON
- ~~Parsed JSON is exported as a global variable, `json`, so you can inspect it in the console~~*> *Typing `json` the in console is not working since Manifest v3. If you need a workaround, paste this snippet into the console:
>
> ```js
> json = JSON.parse(document.getElementById("jsonFormatterRaw").querySelector("pre").innerText)
> ```**Some JSON documents for testing it on:**
https://callumlocke.github.io/json-formatter/## Installation
**Option 1 (recommended)** – Install it from the [Chrome Web Store](https://chrome.google.com/webstore/detail/bcjindcccaagfpapjjmafapmmgkkhgoa).
**Option 2** – Install it from source (see below).
### Development
**Requirements:** [Deno](https://deno.land/) (and [Node](https://nodejs.org/en/) for now).
**Initial setup:**
- Clone repo
- Run `pnpm i` to get TypeScript typings for chrome (or use `npm i` if you prefer)
- Optional: if using VSCode and you need to mess with the Deno build scripts, install the official Deno plugin and set `"deno.enablePaths": ["tasks"]`.**To build it:**
- Run `deno task build`
**To build and rebuild whenever files change:**
- Run `deno task dev`
**To install your local build to Chrome**
- Open Chrome and go to `chrome://extensions`
- Enable "Developer mode",
- Click "Load unpacked",
- Select the `dist` folder you built above.## FAQ
### Why are large numbers not displayed accurately?
This is a [limitation of JavaScript](http://www.ecma-international.org/ecma-262/5.1/#sec-15.7.3.2) and therefore a limitation of JSON as interpreted by your web browser.
- Anything above `Number.MAX_SAFE_INTEGER` (`2^53 - 1` or `9007199254740991`) is adjusted down to that number.
- Anything below `Number.MIN_SAFE_INTEGER` (`-2^53 + 1` or `-9007199254740991`) is adjusted up to that number.
- Extremely precise floating point numbers are rounded to 16 digits.It's not JSON Formatter doing this, it's the native `JSON.parse` in V8. JSON Formatter shows you the **parsed** values, exactly the same as what you'll see after loading the JSON in JavaScript.
If your API endpoint really needs to represent numbers outside JavaScript's safe range, it should **quote them as strings**.
### Why are object keys sometimes in the wrong order?
What you see in JSON Formatter is a representation of the **parsed** object/array. It's the same order you'll get with `Object.keys( JSON.parse(json) )` in JavaScript.
Historically, the JavaScript standard explicitly stated that object keys can be iterated in any order, and V8 took advantage of this by moving numeric string keys (like `"1"` or `"99999"`) to the top to facilitate a small performance optimisation. This V8 implementation detail has since become standardised.
##### But I just want to see exactly what the server spits out
For now, your best option is to just use the "Raw" button to see the raw JSON. This is what the server sent. The "Parsed" buttons represents what you'll get from `JSON.parse`.
In future JSON Formatter might switch from using `JSON.parse` to a custom parser (if performance allows) in order to detect when a value has been 'changed' by parsing and show an appropriate warning.