JSON: The Basics B U I LT I N FA I R F I E L D C O U N T Y: FRONT END

29 Slides664.38 KB

JSON: The Basics B U I LT I N FA I R F I E L D C O U N T Y: FRONT END DEVELOPERS MEETUP T U E S . M AY 1 4 , 2 0 1 3

About Jeff Fox (@jfox015) 16 year web development professional (Almost) entirely self taught Has used various Ajax-esque data technologies since 2000, including XML, MS data islands and AMF for Flash Develops JavaScript based web apps that rely on JSON for data workflow

Overview What is JSON? Comparisons with XML Syntax Data Types Usage Live Examples

What is JSON?

JSON is A lightweight text based data-interchange format Completely language independent Based on a subset of the JavaScript Programming Language Easy to understand, manipulate and generate

JSON is NOT Overly Complex A “document” format A markup language A programming language

Why use JSON? Straightforward syntax Easy to create and manipulate Can be natively parsed in JavaScript using eval() Supported by all major JavaScript frameworks Supported by most backend technologies

JSON vs. XML

Much Like XML Plain text formats “Self-describing“ (human readable) Hierarchical (Values can contain lists of objects or values)

Not Like XML Lighter and faster than XML JSON uses typed objects. All XML values are type-less strings and must be parsed at runtime. Less syntax, no semantics Properties are immediately accessible to JavaScript code

Knocks against JSON Lack of namespaces No inherit validation (XML has DTD and templates, but there is JSONlint) Not extensible It’s basically just not XML

Syntax

JSON Object Syntax Unordered sets of name/value pairs Begins with { (left brace) Ends with } (right brace) Each name is followed by : (colon) Name/value pairs are separated by , (comma)

JSON Example var employeeData { "employee id": 1234567, "name": "Jeff Fox", "hire date": "1/1/2013", "location": "Norwalk, CT", "consultant": false };

Arrays in JSON An ordered collection of values Begins with [ (left bracket) Ends with ] (right bracket) Name/value pairs are separated by , (comma)

JSON Array Example var employeeData { "employee id": 1236937, "name": "Jeff Fox", "hire date": "1/1/2013", "location": "Norwalk, CT", "consultant": false, "random nums": [ 24,65,12,94 ] };

Data Types

Data Types: Strings Sequence of 0 or more Unicode characters Wrapped in "double quotes“ Backslash escapement

Data Types: Numbers Integer Real Scientific No octal or hex No NaN or Infinity – Use null instead.

Data Types: Booleans & Null Booleans: true or false Null: A value that specifies nothing or no value.

Data Types: Objects & Arrays Objects: Unordered key/value pairs wrapped in { } Arrays: Ordered key/value pairs wrapped in []

JSON Usage

How & When to use JSON Transfer data to and from a server Perform asynchronous data calls without requiring a page refresh Working with data stores Compile and save form or user data for local storage

Where is JSON used today? Anywhere and everywhere! And many, many more!

Simple Example

Simple Demo Build a JSON data object in code Display raw output Display formatted output Manipulate via form input

Questions?

Resources Simple Demo on Github: https://github.com/jfox015/BIFC-Simple-JSON -Demo Another JSON Tutorial: http://iviewsource.com/codingtutorials/gettin g-started-with-javascript-object-notation-jsonfor-absolute-beginners/

Back to top button