How JavaScript Object Notation (JSON) works
Most requests and responses to and from IBM® Cloudant® for IBM Cloud® use JSON for formatting the content and structure of the data and responses.
In IBM Cloudant databases, the JSON object is used to represent various structures, including all documents in a database.
Parsing JSON into a JavaScript object is supported through the JSON.parse()
function in JavaScript, or through various libraries that perform the parsing
of the content into a JavaScript object for you. Libraries for parsing and generating JSON are available for many major programming languages.
JSON is used because it's the simplest and easiest solution for working with data that uses a web browser. As a result, JSON structures can be evaluated and used as JavaScript objects within the web browser environment. JSON also integrates with the server-side JavaScript used within IBM Cloudant. JSON documents are always UTF-8 encoded.
Be careful to follow these guidelines:
- Your JSON structures are valid.
- You normalize strings in JSON documents retrieved from IBM Cloudant.
JSON supports the same basic types that are supported by JavaScript: numbers, strings, Booleans, arrays, and objects.
Numbers
Numbers can be integer or floating point values.
Example of a number in JSON format
123
Strings
Strings must be enclosed by double quotation marks. Strings support Unicode characters and escaping a backslash.
Example of a string in JSON format
"A String"
Booleans
A true
or false
value.
Example of a boolean in JSON format
{
"value": true
}
Arrays
A list of values enclosed in brackets. The values that are enclosed can be any valid JSON.
Example of an array in JSON format
[
"one",
2,
"three",
[],
true,
{
"foo":
"bar"
}
]
Example of an array in JSON format (linear)
[ "one", 2, "three", [], true, { "foo": "bar" } ]
Objects
A set of key-value
pairs, such as an associative array, or a hash. The key must be a string, but the value can be any of the supported JSON values.
Example of a JSON object
{
"servings" : 4,
"subtitle" : "Easy to make in advance, and then cook when ready",
"cooktime" : 60,
"title" : "Chicken Coriander"
}