JSON (JavaScript Object Notation) is one of the most popular and widely accepted data exchange format originally specified by Douglas Crockford.
It is currently described by two competing standards, RFC 71592 and ECMA-404. The ECMA standard is minimal, describing only the allowed grammar syntax, whereas the RFC also provides some semantic and security considerations.
Since JSON haven't got any updates, there is only 1 version of JSON, the link below redirects to the original RFC document, which is RFC 4627.
Version | Release Date |
---|---|
Original | 2006-07-28 |
JSON (JavaScript Object Notation) syntax is based on a subset of JavaScript (see also json.org).
A valid JSON expression can be one of the following data types
A JSON string has to be enclosed in double quotes and may contain zero or more Unicode characters; backslash escapes are allowed. Accepted JSON numbers are in E notation. Boolean is one of true
, false
. Null is the reserved keyword null
.
Data type | Examples of valid JSON |
---|---|
### String | "apple" |
"苹果" | |
"\u00c4pfel\n" | |
"" | |
### Number | 3 |
1.4 | |
-1.5e3 | |
### Boolean | true |
false | |
### Null | null |
A JSON Value can be one of: String, Number, Boolean, Null, Object, Array.
ObjectA JSON Object is an comma-separated unordered collection of name:value pairs enclosed in curly brackets where name is a String and value a JSON value.
ArrayA JSON Array is an ordered collection of JSON values.
Example of a JSON array:
["home", "wooden"]
Examples of JSON objects:
{
"id": 1,
"name": "A wooden door",
"price": 12.50,
"tags": ["home", "wooden"]
}
[
1,
2,
[3, 4, 5, 6],
{
"id": 1,
"name": "A wooden door",
"price": 12.50,
"tags": ["home", "wooden"]
}
]
A JSON Object is surrounded by curly braces and contains key-value pairs.
{ "key1": "value1", "key2": "value2", ... }
Keys must be valid strings, thus surrounded by double quotation marks. Values can be JSON objects, numbers, strings, arrays, or one of the following 'literal names': false
, null
, or true
. In a key-value pair, the key is seperated from the value by a colon. Multiple key-value-pairs are separated by commas.
Order in objects is not important. The following JSON object is thus equivalent to the above:
{ "key2": "value2", "key1": "value1", ... }
To sum it all up, this is an example of a valid JSON Object :
{
"image": {
"width": 800,
"height": 600,
"title": "View from 15th Floor",
"thumbnail": {
"url": "http://www.example.com/image/481989943",
"height": 125,
"width": 100
},
"visible": true,
"ids": [116, 943, 234, 38793]
}
}
Throughout this example it is assumed that the 'root' object that is being serialized to JSON is an instance of the following class :
public class MyJson {
}
Example 1 :
An example of an instance of MyJson
, as is:
{}
i.e. since the class has no fields, only curly brackets are serialized. Curly brackets are the common delimiters to represent an object. Notice also how the root object is not serialized as a key-value pair. This is also true for simple types (String, numbers, arrays) when they are not fields of an (outer) object.
Example 2 :
Let's add some fields to MyJson
, and initialize them with some values:
// another class, useful to show how objects are serialized when inside other objects
public class MyOtherJson {}
// an enriched version of our test class
public class MyJson {
String myString = "my string";
int myInt = 5;
double[] myArrayOfDoubles = new double[] { 3.14, 2.72 };
MyOtherJson objectInObject = new MyOtherJson();
}
This is the related JSON representation:
{
"myString" : "my string",
"myInt" : 5,
"myArrayOfDoubles" : [ 3.14, 2.72 ],
"objectInObject" : {}
}
Notice how all the fields are serialized in a key-value structure, where the key is the name of the field holding the value. The common delimiters for arrays are square brackets. Notice also that each key-value pair is followed by a comma, except for the last pair.
A JSON Array is an ordered collection of values. It is surrounded by square braces i.e []
, and values are comma-delimited:
{ "colors" : [ "red", "green", "blue" ] }
JSON Arrays can also contain any valid JSON element, including objects, as in this example of an array with 2 objects (taken from the RFC document):
[
{
"precision": "zip",
"Latitude": 37.7668,
"Longitude": -122.3959,
"Address": "",
"City": "SAN FRANCISCO",
"State": "CA",
"Zip": "94107",
"Country": "US"
},
{
"precision": "zip",
"Latitude": 37.371991,
"Longitude": -122.026020,
"Address": "",
"City": "SUNNYVALE",
"State": "CA",
"Zip": "94085",
"Country": "US"
}
]
They can also contain elements with mixed types, for example:
[
"red",
51,
true,
null,
{
"state": "complete"
}
]
A common mistake when writing JSON arrays (and objects) is to leave a trailing comma after the last element. This is common pattern in many languages, but unfortunately isn't valid in JSON. For example, the following array is invalid:
[
1,
2,
]
To make this valid, you would need to remove the comma after the last element, turning it into:
[
1,
2
]
JSON is a very strict format (see http://json.org). That makes it easy to parse and write for machines but surprises humans when an inconspicuous mistakes breaks the document.
Unlike most programming languages your are not allowed to add a trailing comma:
{
a: 1,
b: 2,
c: 3
}
Adding a comma after 3
will produce a synax error.
The same issue exists for arrays:
[
1,
2
]
You must take extra care if you need to reorder the items.
{
a: 1,
b: 2,
c: 3
d: 4
}
Since trailing commas are not allowed, it is easy to forget to append one before adding a new value (in this case after 3
).
JSON does not allow comments as it is a data-interchange format. This is still a hot topic though with no clear answers other than not to use them.
There are several workarounds:
{
"//": "comment",
"data": 1
}
{
"data": "comment",
"data": 1
}
The second data
entry will overwrite the comment in most parsers.
To make it easier to write JSON use an IDE that checks for syntax errors and provides syntax coloring. Plugins are available for most editors.
When you develop applications and tools, use JSON internally and as a protocol but try not to expose it in places where a human would likely be required to edit it by hand (except for debugging).
Evaluate other formats that are better suited for this use, like:
JSON arrays represent a collection of objects. In JS, theres a bunch of collection functions off of them such as slice
, pop
, push
. Objects have just more raw data.
A JSONArray is an ordered sequence of values. Its external text form is a string wrapped in square brackets with commas separating the values.
A JSONObject is an unordered collection of name/value pairs. Its external form is a string wrapped in curly braces with colons between the names and values, and commas between the values and names.
Object - key and value, Array - numerals, strings, booleans. When do you use this or that?
You can think of Arrays as "is a/an" and Objects as "has a". Lets use "Fruit" as example. Every item in fruit array is a type of fruit.
array fruit : [orange, mango, banana]
Arrays can contain objects,strings, numbers, arrays, but lets deal with only objects and arrays.
array fruit : [orange:[], mango:{}, banana:{}]
. You can see that orange is an array too. It implies any item that goes int orange is a type of orange, say: bitter_orange, mandarin, sweet_orange.
for fruit object, any item in it is an attribute of fruit. thus the fruit has a
object fruit :{seed:{}, endocarp:{},flesh:{}}
This also implies that anything within the seed object should be property of seed, say: colour, ..
JSON is primarily a language that allows serializing javascript objects into strings. So upon deserializing a JSON string you should get a javascript object structure. If your json deserializes into an object that stores 100 objects called object1 to object100 then that's going to be very inconvenient. Most deserializers will expect you to have known objects and arrays of known objects so that they can convert the strings into the actual object structure in the language you're using. Also this is a question that the philosophy of object oriented design would answer you.
credits to all particiapnts What are the differences between using JSON arrays vs JSON objects?