2014-03-01 19:43:03 +00:00
---
2024-12-09 04:34:00 -07:00
name: JSON
2014-03-01 19:43:03 +00:00
filename: learnjson.json
contributors:
- ["Anna Harren", "https://github.com/iirelu"]
2014-06-08 22:00:14 +01:00
- ["Marco Scannadinari", "https://github.com/marcoms"]
2015-10-08 15:49:51 +05:30
- ["himanshu", "https://github.com/himanshu81494"]
2015-10-15 15:30:59 -05:00
- ["Michael Neth", "https://github.com/infernocloud"]
2018-11-12 21:14:08 +02:00
- ["Athanasios Emmanouilidis", "https://github.com/athanasiosem"]
2014-03-01 19:43:03 +00:00
---
2020-10-20 15:47:53 +08:00
JSON is an extremely simple data-interchange format. As [json.org ](https://json.org ) says, it is easy for humans to read and write and for machines to parse and generate.
2014-03-01 19:43:03 +00:00
2023-07-09 06:02:47 +00:00
A piece of JSON can be any value of the types listed later, but in practice almost always represents either:
2017-08-16 12:32:09 -07:00
2015-10-20 14:24:32 +05:30
* A collection of name/value pairs (`{ }` ). In various languages, this is realized as an object, record, struct, dictionary, hash table, keyed list, or associative array.
* An ordered list of values (`[ ]` ). In various languages, this is realized as an array, vector, list, or sequence.
2015-10-08 15:49:51 +05:30
2015-10-20 14:24:32 +05:30
JSON in its purest form has no actual comments, but most parsers will accept C-style (`//` , `/* */` ) comments. Some parsers also tolerate a trailing comma (i.e. a comma after the last element of an array or the after the last property of an object), but they should be avoided for better compatibility.
2015-10-15 15:35:13 -05:00
2015-10-20 14:24:32 +05:30
For the purposes of this tutorial, everything is going to be 100% valid JSON. Luckily, it kind of speaks for itself.
2015-10-15 15:35:13 -05:00
2015-10-20 14:24:32 +05:30
Supported data types:
2015-10-15 15:30:21 -05:00
2015-10-20 14:24:32 +05:30
* Strings: `"hello"` , `"\"A quote.\""` , `"\u0abe"` , `"Newline.\n"`
* Numbers: `23` , `0.11` , `12e10` , `3.141e-10` , `1.23e+4`
* Objects: `{ "key": "value" }`
* Arrays: `["Values"]`
* Miscellaneous: `true` , `false` , `null`
2015-10-15 15:35:13 -05:00
2014-03-01 19:43:03 +00:00
```json
{
2014-06-08 22:00:14 +01:00
"key": "value",
2015-10-07 23:11:24 -04:00
2014-09-21 18:27:43 +02:00
"keys": "must always be enclosed in double quotes",
2014-03-01 19:43:03 +00:00
"numbers": 0,
2014-03-01 19:46:36 +00:00
"strings": "Hellø, wørld. All unicode is allowed, along with \"escaping\".",
2014-03-01 19:43:03 +00:00
"has bools?": true,
"nothingness": null,
"big number": 1.2e+100,
"objects": {
"comment": "Most of your structure will come from objects.",
2014-03-01 19:46:36 +00:00
"array": [0, 1, 2, 3, "Arrays can have anything in them.", 5],
2014-03-01 19:43:03 +00:00
"another object": {
"comment": "These things can be nested, very useful."
}
},
"silliness": [
{
"sources of potassium": ["bananas"]
},
[
[1, 0, 0, 0],
[0, 1, 0, 0],
[0, 0, 1, "neo"],
[0, 0, 0, 1]
]
],
2015-10-07 23:11:24 -04:00
2014-06-08 22:00:14 +01:00
"alternative style": {
"comment": "check this out!"
2015-10-20 14:24:32 +05:30
, "comma position": "doesn't matter, if it's before the next key, it's valid"
2014-06-13 19:20:21 +01:00
, "another comment": "how nice"
2015-10-20 14:24:32 +05:30
},
2015-10-15 15:30:21 -05:00
2015-10-20 14:24:32 +05:30
"whitespace": "Does not matter.",
2015-10-15 15:30:21 -05:00
2015-10-20 14:24:32 +05:30
"that was short": "And done. You now know everything JSON has to offer."
}
2015-10-15 15:30:21 -05:00
```
2015-10-20 14:24:32 +05:30
## Further Reading
2020-10-20 15:47:53 +08:00
* [JSON.org ](https://json.org ) All of JSON beautifully explained using flowchart-like graphics.
2018-10-20 21:19:46 +05:30
* [JSON Tutorial ](https://www.youtube.com/watch?v=wI1CWzNtE-M ) A concise introduction to JSON.