Javascript Object Notation
JavaScript Object Notation, JSON for short, is file format for storing and exchanging structured data.
JSON is a human-readable text-based format based on how objects are defined in Javascript.
JSON data can be easily created and decoded in Javascript and most other modern programming languages.
Table of Contents
- Structured Data
- Structured Data in XML
- Structured Data in JS - Arrays & Objects
- JSON Structured Data
- JSON Building Blocks
- Javascript Objects and Arrays
- File Extension and MIME Type
- Creating JSON with Javascript
- Decoding JSON with Javascript
- Accessing JSON Data in Javascript
- Viewing and Debugging JSON
- Further Reading
Structured Data
In order for computer programs to use and exchange information we must structure the data hierarchically and descriptively.
For example, to store information about a collection of people we might need some way to:
- Specify each person’s name
- Specify each person’s age.
- Specify each person’s address. (Including a street, city, province and postal code.)
- Group the people together.
Structured Data in XML
Here’s that same structured data written as XML, the Extensible Markup Language.
<?xml version="1.0" encoding="UTF-8"?>
<people>
<person>
<name>Wally Glutton</name>
<age>40</age>
<address>
<street>39 Good St.</street>
<city>Winnipeg</city>
<province>Manitoba</province>
<postal_code>R3J 2K9</postal_code>
</address>
</person>
<person>
<name>Daisy Glutton</name>
<age>38</age>
<address>
<street>8 Fine Ave.</street>
<city>Winnipeg</city>
<province>Manitoba</province>
<postal_code>R3R 2B2</postal_code>
</address>
</person>
</people>
Before JSON came around in the early 2000s, XML was the defacto way to send structured data between applications.
Structured Data in JS - Arrays & Objects
Using Javascript we might encode our people data using nested objects and arrays, like this:
var people = [
{
name: "Wally Glutton",
age: 40,
address: {
street: "39 Good St.",
city: "Winnipeg",
province: "Manitoba",
postal_code: "R3J 2K9",
},
},
{
name: "Daisy Glutton",
age: 38,
address: {
street: "8 Fine Ave",
city: "Winnipeg",
province: "Manitoba",
postal_code: "R3R 2B2",
},
},
];
JSON Structured Data
The JSON version of this structure data is just like the Javascript version with three differences: The object keys are now strings, the variable assignment was removed, and the trailing semi-colon was removed.
[
{
"name": "Wally Glutton",
"age": 40,
"address": {
"street": "39 Good St.",
"city": "Winnipeg",
"province": "Manitoba",
"postal_code": "R3J 2K9"
}
},
{
"name": "Daisy Glutton",
"age": 38,
"address": {
"street": "8 Fine Ave",
"city": "Winnipeg",
"province": "Manitoba",
"postal_code": "R3R 2B2"
}
}
]
This is why JSON stands for Javascript Object Notation. It’s how we define structured objects in Javascript.
Notice how much more lightweight it is compared with XML. It’s much shorter than the XML version and I’d argue much easier for a human to read without all the angle brackets.
JSON can also be minified (all whitespace removed) to be more efficient to transfer:
[{"name":"Wally Glutton","age":40,"address":{"street":"39 Good St.","city":"Winnipeg","province":"Manitoba","postal_code":"R3J 2K9"}},{"name":"Daisy Glutton","age":38,"address":{"street":"8 Fine Ave","city":"Winnipeg","province":"Manitoba","postal_code":"R3R 2B2"}}]
Douglas Crockford discovered and standardized JSON in the early 2000s. The diagrams that follow are from his json.org website. Crockford describes JSON as “a light-weight, language independent, data interchange format”.
JSON Building Blocks
Although JSON is Javascript, there are some extra constraints.
JSON data must be contained in either an Array or an Object and the values contained within must be of the follow types:
- String
- Number (integer or float)
- Boolean
- null
- Arrays
- Objects
Further more, all strings must be double quoted and object keys must be strings.
Note that both Arrays and Objects can be nested within the JSON data.
Javascript Objects and Arrays
Since a JSON structure must be contained in either an Object or an Array it’s worth revisiting these structures.
Objects in Javascript are built as hashes (or what are sometimes called associative arrays). Objects are defined as comma-delimited collections of key/value pairs wrapped in curly braces.
Arrays in Javascript are defined as comma-delimited collections of values wrapped in square braces.
When building JSON we should use Arrays when storing collections of “things” and objects for storing named properties of “things”.
File Extension and MIME Type
The file extension that should be used for JSON files is .json
.
A MIME type or internet media type is a two-part identifier for file formats transmitted on the Internet.
When sending or receiving JSON the specified MIME type should be application/json
Some legacy systems, however, may use text/json
or text/javascript
.
Creating JSON with Javascript
Although we saw earlier that JSON is Javascript (with some constraints) we can take Javascript Objects and Arrays and turn them into JSON strings by “stringifying” them:
// Assumes access to the people variable defined above:
var peopleJSON = JSON.stringify(people);
// View the JSON string in the console:
console.log(peopleJSON);
Once JSON has been stringified it is just a string, you can no longer index into it to retrieve values.
Decoding JSON with Javascript
If you receive JSON as a String in your Javascript you can parse it to an Object/Array structure:
// Assuming the existing of a JSON string called peopleJSON:
var people = JSON.parse(peopleJSON);
Accessing JSON Data in Javascript
Here’s how we could access JSON nested data in Javascript assuming we have our people JSON stored in a peopleJSON String:
var people = JSON.parse(peopleJSON);
// Print the first person's name
console.log(people[0]["name"]);
// Print the second person's city
console.log(people[1]["address"]["city"]);
// Loop through the people and print out some details.
for (var i = 0; i < people.length; i++) {
var name = people[i]["name"];
var age = people[i]["age"];
var postal_code = people[i]["address"]["postal_code"];
console.log(
name +
" is " +
age +
" years old and lives in the " +
postal_code +
" postal code."
);
}
When accessing JSON data in a language other than Javascript we need to decode it to a native data structure first.
Actually, even in Javascript if we receive the JSON data as text it will need to be decoded to a Javascript data structure before it can be used.
Viewing and Debugging JSON
JSON data can be difficult to debug, especially when it’s computer-generated without extra whitespace and indentation.
There are online tools you can use to validate and “pretty print” the JSON you are working with for debugging purposes.
The JSON Viewer available at codebeautify.org/jsonviewer can be used to validate (check for syntax errors), beautify (make more human readable) and minify (remove all whitespace) JSON data. It can also be used to convert JSON to XML or CSV formats.
Further Reading
- Official JSON Webpage
- RFC 4627 - Crockford’s original “Request for Comment” on the JSON specification to the Network Working Group, 2006.
- RFC 7159 - Current JSON specification as an RFC to the Internet Engineering Task Force (IETF), 2014.