<ahref="labs/architecture-examples/backbone_marionette/"data-source="http://marionettejs.com"data-content="Backbone.Marionette is a composite application library for Backbone.js that aims to simplify the construction of large scale JavaScript applications.">MarionetteJS</a>
<ahref="labs/architecture-examples/backbone_marionette/"data-source="http://marionettejs.com"data-content="Backbone.Marionette is a composite application library for Backbone.js that aims to simplify the construction of large scale JavaScript applications.">MarionetteJS</a>
</li>
</li>
<liclass="routing labs">
<liclass="routing labs">
...
@@ -184,9 +184,9 @@
...
@@ -184,9 +184,9 @@
<liclass="routing labs">
<liclass="routing labs">
<ahref="labs/dependency-examples/angularjs_require/"data-source="http://angularjs.org"data-content="What HTML would have been had it been designed for web apps. This is an example of using it with AMD modules.">AngularJS + RequireJS</a>
<ahref="labs/dependency-examples/angularjs_require/"data-source="http://angularjs.org"data-content="What HTML would have been had it been designed for web apps. This is an example of using it with AMD modules.">AngularJS + RequireJS</a>
</li>
</li>
<liclass="routing labs">
<liclass="routing labs">
<ahref="labs/dependency-examples/canjs_require/"data-source="http://canjs.us"data-content="CanJS is a client-side, JavaScript framework that makes building rich web applications easy. The AMD version lets you use the framework in a fully modular fashion and will only what you actually need.">CanJS + RequireJS</a>
<ahref="labs/dependency-examples/canjs_require/"data-source="http://canjs.us"data-content="CanJS is a client-side, JavaScript framework that makes building rich web applications easy. The AMD version lets you use the framework in a fully modular fashion and will only what you actually need.">CanJS + RequireJS</a>
</li>
</li>
<liclass="routing labs">
<liclass="routing labs">
<ahref="labs/dependency-examples/troopjs/"data-source="https://github.com/troopjs/"data-content="TroopJS attempts to package popular front-end technologies and bind them with minimal effort for the developer. It includes jQuery for DOM manipulation, ComposeJS for object composition, RequireJS for modularity and Has.js for feature detection. On top, it includes Pub/Sub support, templating, weaving (widgets to DOM) and auto-wiring.">TroopJS</a>
<ahref="labs/dependency-examples/troopjs/"data-source="https://github.com/troopjs/"data-content="TroopJS attempts to package popular front-end technologies and bind them with minimal effort for the developer. It includes jQuery for DOM manipulation, ComposeJS for object composition, RequireJS for modularity and Has.js for feature detection. On top, it includes Pub/Sub support, templating, weaving (widgets to DOM) and auto-wiring.">TroopJS</a>
</li>
</li>
...
@@ -195,23 +195,22 @@
...
@@ -195,23 +195,22 @@
</li>
</li>
</ul>
</ul>
<hr>
<hr>
<h2>Real-time</h2>
<h2>Real-time</h2>
<ulclass="applist">
<ulclass="applist">
<liclass="labs">
<liclass="labs">
<ahref="http://todomvc.meteor.com"data-source="http://meteor.com"data-content="Meteor is an ultra-simple environment for building modern websites.A Meteor application is a mix of JavaScript that runs inside a client web browser, JavaScript that runs on the Meteor server inside a Node.js container, and all the supporting HTML fragments, CSS rules, and static assets. Meteor automates the packaging and transmission of these different components. And, it is quite flexible about how you choose to structure those components in your file tree.">Meteor</a>
<ahref="http://todomvc.meteor.com"data-source="http://meteor.com"data-content="Meteor is an ultra-simple environment for building modern websites.A Meteor application is a mix of JavaScript that runs inside a client web browser, JavaScript that runs on the Meteor server inside a Node.js container, and all the supporting HTML fragments, CSS rules, and static assets. Meteor automates the packaging and transmission of these different components. And, it is quite flexible about how you choose to structure those components in your file tree.">Meteor</a>
</li>
</li>
<liclass="labs">
<liclass="labs">
<ahref="http://todomvc.derbyjs.com"data-source="http://derbyjs.com"data-content="MVC framework making it easy to write realtime, collaborative applications that run in both Node.js and browsers.">Derby</a>
<ahref="http://todomvc.derbyjs.com"data-source="http://derbyjs.com"data-content="MVC framework making it easy to write realtime, collaborative applications that run in both Node.js and browsers.">Derby</a>
</li>
</li>
<liclass="labs">
<liclass="labs">
<ahref="labs/architecture-examples/socketstream/README.md"data-source="http://www.socketstream.org"data-content="SocketStream is a fast, modular Node.js web framework dedicated to building realtime single-page apps">SocketStream</a>
<ahref="labs/architecture-examples/socketstream/README.md"data-source="http://www.socketstream.org"data-content="SocketStream is a fast, modular Node.js web framework dedicated to building realtime single-page apps">SocketStream</a>
</li>
</li>
<liclass="routing labs">
<liclass="routing labs">
<ahref="http://todomvc.crypho.com"data-source="https://github.com/ggozad/Backbone.xmpp"data-content="Backbone.xmpp is a drop-in replacement for Backbone’s RESTful API, allowing models/collections to be persisted on XMPP Pub-Sub nodes providing real-time updates.">Backbone.xmpp</a>
<ahref="http://todomvc.crypho.com"data-source="https://github.com/ggozad/Backbone.xmpp"data-content="Backbone.xmpp is a drop-in replacement for Backbone’s RESTful API, allowing models/collections to be persisted on XMPP Pub-Sub nodes providing real-time updates.">Backbone.xmpp</a>
</li>
</li>
</ul>
</ul>
<hr>
<hr>
<h2>Compare these to a non-framework implementation</h2>
<h2>Compare these to a non-framework implementation</h2>
<ulclass="applist">
<ulclass="applist">
<li>
<li>
...
@@ -279,7 +278,6 @@
...
@@ -279,7 +278,6 @@
</p>
</p>
</div>
</div>
</div>
</div>
<hr>
<hr>
<footerclass="credit">
<footerclass="credit">
<p>Brought to you by<ahref="https://github.com/addyosmani"><imgsrc="http://gravatar.com/avatar/96270e4c3e5e9806cf7245475c00b275?s=80"width="40"height="40"alt="Addy Osmani">Addy Osmani</a> and <ahref="https://github.com/sindresorhus"><imgsrc="http://gravatar.com/avatar/d36a92237c75c5337c17b60d90686bf9.png?s=80"width="40"height="40"alt="Sindre Sorhus">Sindre Sorhus</a></p>
<p>Brought to you by<ahref="https://github.com/addyosmani"><imgsrc="http://gravatar.com/avatar/96270e4c3e5e9806cf7245475c00b275?s=80"width="40"height="40"alt="Addy Osmani">Addy Osmani</a> and <ahref="https://github.com/sindresorhus"><imgsrc="http://gravatar.com/avatar/d36a92237c75c5337c17b60d90686bf9.png?s=80"width="40"height="40"alt="Sindre Sorhus">Sindre Sorhus</a></p>