Web Apps: Past & Future
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
17.11.2015
Michael Bromley
Gentics Software
Current Technology
Limitations & Problems
Solutions & Innovations
Increased scope & complexity
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
The Pre-JavaScript Period
- Invention of the web: 1990
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
The Pre-JavaScript Period
Problems Solved
- Websites possible
New Problems
- Poor interactivity
- Unresponsive UIs
- No drop-down menus (!!)
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
The DHTML Period
- May 1995: Brendan Eich creates JavaScript
- November 1996: Netscape submit standard to Ecma.
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
The DHTML Period
data:image/s3,"s3://crabby-images/9a177/9a17731a2ac6c7d4b2b2b2fbab7fa0ff774f3ee5" alt=""
data:image/s3,"s3://crabby-images/6cf7f/6cf7f3625716d2af3023d98d61f0362faf0bd6b5" alt=""
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
The DHTML Period
Problems Solved
- Better user experience
- More interactive
- Client-side logic (fewer network calls)
New Problems
- Bad APIs (DOM)
- Inconsistent APIs (DOM!)
- No async data
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
data:image/s3,"s3://crabby-images/9d1d7/9d1d7f17aaf1906d52e577e04b4476e73dc50154" alt=""
The jQuery & AJAX Period
- Prototype.js: 2005
- Dojo: 2005
- jQuery: 2006
- MooTools: 2006
- YUI: 2006
- Gmail: 2005
- XmlHttpRequest Spec: 2006
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
The jQuery & AJAX Period
// native DOM API
if (el.classList)
el.classList.contains(className);
else
new RegExp('(^| )' + className
+ '( |$)', 'gi').test(el.className);
// with jQuery
$(el).hasClass(className);
vs.
var request = new XMLHttpRequest();
request.open('GET', '/my/url', true);
request.onload = function() {
if (request.status >= 200 && request.status < 400) {
// Success!
var data = JSON.parse(request.responseText);
} else {
// error response
}
};
request.onerror = function() {
// connection error of some sort
};
request.send();
$.getJSON('/my/url', function(data) {
});
vs.
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
The jQuery & AJAX Period
Problems Solved
- Concise, intuitive DOM APIs
- Fixes browser inconsistencies
- AJAX = real web apps possible
New Problems
- No code structure = spaghetti
- Hidden coupling to DOM
- Data being stored in DOM
- Keeping model / UI in sync
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
data:image/s3,"s3://crabby-images/9d1d7/9d1d7f17aaf1906d52e577e04b4476e73dc50154" alt=""
Evolutionary Dead Ends
data:image/s3,"s3://crabby-images/73eac/73eacceb17c0cbe1375e0c1b32786596b31bf625" alt=""
data:image/s3,"s3://crabby-images/544d1/544d1b89b84eef81ecef9fb7aca12aadc07c3566" alt=""
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Evolutionary Dead Ends
Problems Solved
- Features!
New Problems
- Need plugins to work
- Proprietary
- Performance / resource usage
- Poor security record
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
data:image/s3,"s3://crabby-images/9d1d7/9d1d7f17aaf1906d52e577e04b4476e73dc50154" alt=""
The SPA Revolution
- Angular: 2009
- Backbone: 2010
- Knockout: 2010
- Ember: 2011
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
The SPA Revolution
Problems Solved
- Code structure (MVC, etc.)
- Data-binding is trivial
- Fully featured frameworks (routing, ajax, etc.) for entire app.
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
data:image/s3,"s3://crabby-images/9d1d7/9d1d7f17aaf1906d52e577e04b4476e73dc50154" alt=""
Current Technology
Limitations & Problems
Solutions & Innovations
Increased scope & complexity
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
The SPA Revolution
Today's Problems: Complexity
- Managing state
- Managing complex data flow
- Managing concurrency & real-time apps
- Managing huge code bases & teams
- Keeping the app reliable and predictable
- Mobile experience
- SEO
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Solutions?
- RxJS
- Bacon.js
- Cycle.js
- Immutable.js
- Angular2
- virtual-dom
- universal javascript
- Babel
- Elm
- ES6/2015
- TypeScript
- React
- Flux
- Redux
- React Native
- NativeScript
- Meteor
- Aurelia
- Webpack
- System.js
- Ionic
- etc.
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Solutions!
- Component-based architecture
- One-way data-flow
- Functional programming & immutability
- Reactive programming
- Modular rendering
- Transpilation
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Component Architecture
data:image/s3,"s3://crabby-images/eaecb/eaecbb22765c48a154e1f9792b921b81220d325e" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/636c8/636c8fc612190649124628837ab7d547cd445a3a" alt=""
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Component Architecture
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
App
Sidebar
Contacts
Menu
Contents
ChatWindow
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Component Architecture
<App />
<Sidebar />
<Contents />
<Contacts />
<Menu />
<ChatWindow />
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
One-Way Data Flow
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/faf32/faf32b51b1177595a9b523ad0464fe8a65df33ba" alt=""
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
data:image/s3,"s3://crabby-images/a578b/a578bd2c8cfbaae9e525ced993c4e77afda7e61a" alt=""
One-Way Data Flow
Parent Component
Child Component
Data
Callback
Callback( )
Data
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
One-Way Data Flow
- Allows efficient change detection
- Allows a predictable order of execution
- = Easier to understand the code.
- = Less error-prone code, easier to debug
Advantages
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
One-Way Data Flow
Resources
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
- Thinking In React
https://facebook.github.io/react/docs/thinking-in-react.html - Video: Angular2 Data Flow
https://www.youtube.com/watch?v=bVI5gGTEQ_U
Functional Programming
& Immutability
- Style of programming
- Simple functions composed together
- Avoids mutation
- Avoids side-effects
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Functional Programming
& Immutability
- Concise, declarative code
- More robust code
- More testable
Advantages
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
function square(x) {
return x * x;
}
let a = [1, 2, 3, 4];
let b = a.map(square);
// b = [1, 4, 9, 16];
Functional Programming
& Immutability
data:image/s3,"s3://crabby-images/a8ba5/a8ba5531f3d8cda3af2fd7ddf055aaec10cbcdf2" alt=""
Function Programming in Javascript (interactive tutorial)
Resources
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Immutable.js:
Reactive Programming
- Programming with async data streams
merge(a, b)
a
b
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Reactive Programming
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
/* Get stock data somehow */
var source = getStockData();
source
.filter(quote => quote.price > 30)
.map(quote => quote.price)
.forEach(price => {
console.log('Prices higher than $30: $' + price);
});
Reactive Programming
Advantages
- Modern UIs fit with async streams
- User input events
- Real-time/web socket updates
- Works well with Functional principles
- Less state to manage
- Terse, declarative code
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Reactive Programming
Resources
- The introduction to Reactive Programming you've been missing
https://gist.github.com/staltz/868e7e9bc2a7b8c1f754 -
Ben Lesh Talks RxJS at Modern Web UI
https://www.youtube.com/watch?v=yk_6eU3Hcwo
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Modular Rendering
Browser
JavaScript App
DOM (user interface)
Renders
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Modular Rendering
Browser
JavaScript App
(core)
DOM (user interface)
Renders
JavaScript App
DOM renderer
Ready to render
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Modular Rendering
Browser
JavaScript App (core)
DOM renderer
Server renderer
Server
Mobile native renderer
Mobile App
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Modular Rendering
Resources
- React Native
https://facebook.github.io/react-native/ -
NativeScript
https://www.nativescript.org/ - Angular 2 Rendering Architecture
goo.gl/Mqe2oD
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Transpilation
- TypeScript
- Dart
- Elm
- JSX
- ClojureScript
- CoffeeScript
Transpiler
(e.g. Babel)
JavaScript
Browser
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Transpilation
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Why Transpile?
- Use the latest JS features today
- Use any of over 100 other languages
- Features: types, decorators, immutability etc.
Transpilation
data:image/s3,"s3://crabby-images/c91b1/c91b188fa7be03f76241d0a521f17a78e00efbd2" alt=""
data:image/s3,"s3://crabby-images/439c9/439c9ff033af3e7fc282719baf61f58d6bef8dc0" alt=""
- Adds a type system to JavaScript
- Much improved tooling
- Static type checking
- Catches bugs before run-time
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Transpilation
Resources
- TypeScript Playground
http://www.typescriptlang.org/Playground - BabelJS
https://babeljs.io/ - List of languages that compile to JS
https://github.com/jashkenas/coffeescript/wiki/list-of-languages-that-compile-to-js
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
Summary
- Our job is to solve problems
- ...continually
- Today's problems are big & complex
- There are many solutions
- Always keep learning
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
data:image/s3,"s3://crabby-images/9d1d7/9d1d7f17aaf1906d52e577e04b4476e73dc50154" alt=""
Thank You!
Slides: https://slides.com/michaelbromley/deck-6/
data:image/s3,"s3://crabby-images/3ca65/3ca655308cc366e43e31867580e372335f62cc85" alt=""
deck
By Michael Bromley
deck
- 3,735