knockout.js & signalr

17
Knockout.js Dynamic Web UIs and the MVVM pattern Ægir Þorsteinsson Landsbankinn @thorsteinsson http://thorsteinsson.is/

Upload: agir-borsteinsson

Post on 18-Jan-2015

4.331 views

Category:

Technology


0 download

DESCRIPTION

 

TRANSCRIPT

Page 1: Knockout.js & SignalR

Knockout.jsDynamic Web UIs and the MVVM pattern

Ægir Þorsteinsson

Landsbankinn@thorsteinsson

http://thorsteinsson.is/

Page 2: Knockout.js & SignalR

Knockout.jsMVVM for HTML and JavaScript

~ 1 year old; active community

Community project

(not run by Microsoft)

Open source JavaScript library

(MIT license – source on GitHub)

Page 3: Knockout.js & SignalR

Knockout.jsWhat is it good for?

Rich client-side interactivity

MVVM pattern

Wide browser support

6+ 2+

Bye bye, overlapping mess of interrelated event handlers

Hello, object-oriented JavaScriptand declarative bindings

http://knockoutjs.com

Page 4: Knockout.js & SignalR

MVVM in JavaScript

“Model”

ViewModel

View

Server

Brow

ser

Ajax / form posts

Automatic

Any server-side technology

JavaScript + observables

HTML + declarative bindings

Page 5: Knockout.js & SignalR

Examples

Page 6: Knockout.js & SignalR

Examples

Page 7: Knockout.js & SignalR

Commonly-used bindings

clickevent submit

visible

checked

disable

value options

selectedOptions

text html

css style

enable

attr

foreachwithif

Content & appearance

Events

Form fields

Control flow (KO 1.3)

template Templating

Page 8: Knockout.js & SignalR

Knockout.jsHow is it different?

Automatic dependency

tracking

Declarative bindings

Integrated templating

Page 9: Knockout.js & SignalR

http://knockoutjs.com

Page 10: Knockout.js & SignalR

SignalRPersistent connection between JS and ASP.NET

~ 1 year old; active community

Community project

(not run by Microsoft)

Open source JavaScript library

(MIT license – source on GitHub)

Page 11: Knockout.js & SignalR

SignalR

ASP.NET

JavaScript

Server

Brow

ser

Long polling / web sockets

Page 12: Knockout.js & SignalR

SignalR

http://aegir.pagekite.me/chat

Page 13: Knockout.js & SignalR

SignalR

Page 14: Knockout.js & SignalR

SignalR

Page 15: Knockout.js & SignalR

SignalR

Page 16: Knockout.js & SignalR

More information

http://knockoutjs.com

http://signalr.net

http://learn.knockoutjs.com

http://knockmeout.net

Page 17: Knockout.js & SignalR

Questions?

Ægir Þorsteinsson

Landsbankinn@thorsteinsson

http://thorsteinsson.is/