<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Backbone.Declarative.Views 4.1.1, plain Backbone demo (AMD)</title>
<meta name="description" content="Backbone.Declarative.Views 4.1.1, plain Backbone demo (AMD)">
<!-- ATTN Foundation loaded without JS - stay clear of JS-driven widgets, or add the JS setup -->
<!--
ATTN jQuery 1.x is used here, making the demo compatible with oldIE. As a side effect,
Foundation 5 JS can't be used reliably (requires jQuery 2.x). Stay clear, or switch to
jQuery 2.x, available in the top-level bower_components.
-->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/foundation/5.5.3/css/normalize.css">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/foundation/5.5.3/css/foundation.css">
<link rel="stylesheet" href="https://cdn.rawgit.com/hashchange/backbone.declarative.views/4.1.1/demo/amd/amd.css">
<!-- Fix HTML5 tags in oldIE and other lacking legacy browsers -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/modernizr/2.8.3/modernizr.js"></script>
<script id="list-template" data-tag-name="ul" data-class-name="list small-block-grid-4 medium-block-grid-8 large-block-grid-10" type="text/x-template">
<!-- no content - template just exists for the el definition -->
</script>
<script id="item-template" data-tag-name="li" data-class-name="item" type="text/x-template">
<%= number %>
</script>
<script id="stats-template" data-tag-name="p" data-class-name="row" type="text/x-template">
Generating <%= itemViewCount %> item views took <%= duration %>ms. In total, it took <%= renderDuration %>ms until they had all been appended to the DOM. Finally, when painting was over, <%= totalDuration %>ms had passed.
</script>
</head>
<body>
<section id="header">
<h1 class="row">AMD setup: Plain Backbone</h1>
</section>
<section class="stats">
<h2 class="row">Performance statistics</h2>
</section>
<section class="content">
<h2 class="row">Content</h2>
<div class="container row"></div>
</section>
<script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.3.1/require.js"></script>
<script src="https://cdn.rawgit.com/hashchange/backbone.declarative.views/4.1.1/demo/amd/jsbin/map-config.js"></script>
<script src="https://cdn.rawgit.com/hashchange/backbone.declarative.views/4.1.1/demo/amd/rjs/output/parts/vendor.js"></script>
</body>
</html>
// base.js
define( 'local.base',[
'underscore',
'backbone',
'usertiming',
'backbone.declarative.views'
], function ( _, Backbone, performance ) {
var eventBus = _.extend( {}, Backbone.Events ),
Model = Backbone.Model.extend(),
Collection = Backbone.Collection.extend(
{ model: Model },
{
create: function ( modelCount ) {
var i,
collection = new Collection(),
models = [];
for ( i = 0; i < modelCount; i++ ) models.push( new collection.model( { number: i + 1 } ) );
collection.reset( models );
return collection;
}
}
),
StatsView = Backbone.View.extend( {
template: "#stats-template",
parent: ".stats",
initialize: function ( options ) {
var compiledTemplate = this.declarativeViews.getCachedTemplate().compiled;
this.template = compiledTemplate || _.template( this.declarativeViews.getCachedTemplate(). html );
options || ( options = {} );
if ( options.parent ) this.parent = options.parent;
this.$parent = Backbone.$( this.parent );
this.$el.appendTo( this.$parent );
this.listenTo( eventBus, "createStats", this.render );
},
render: function ( stats ) {
stats.totalDuration = Math.round( this.getTotalDuration() );
this.$el.html( this.template( stats ) );
},
getTotalDuration: function () {
// Query the document height. This is to assess the true total render time, including the painting.
// The calculation of the document height should be blocked by the browser until all item elements have
// been painted.
var docHeight = $( document ).height();
performance.measure( "paint", "create-itemViews-start" );
return performance.getEntriesByName( "paint" )[0].duration;
}
} );
Backbone.DeclarativeViews.custom.compiler = _.template;
return {
Model: Model,
Collection: Collection,
StatsView: StatsView,
eventBus: eventBus
}
} );
// views-backbone.js
define( 'local.views-backbone',[
'underscore',
'backbone',
'usertiming',
'local.base',
'backbone.declarative.views'
], function ( _, Backbone, performance, base ) {
var ItemView = Backbone.View.extend( {
initialize: function ( options ) {
this.template = this.declarativeViews.getCachedTemplate().compiled;
},
render: function () {
this.$el.html( this.template( this.model.attributes ) );
return this;
},
appendTo: function ( $parent ) {
if ( !( $parent instanceof Backbone.$ ) ) $parent = Backbone.$( $parent );
$parent.append( this.$el );
return this;
}
} ),
ListView = Backbone.View.extend( {
initialize: function ( options ) {
options || ( options = {} ); // jshint ignore:line
if ( options.ItemView ) this.ItemView = options.ItemView;
if ( options.parent ) this.parent = options.parent;
this.$parent = Backbone.$( this.parent );
},
render: function () {
var duration, renderDuration,
els = [];
this.itemViews = [];
// Start timer
performance.clearMarks();
performance.clearMeasures();
performance.mark( "create-itemViews-start" );
this.collection.each( function ( model ) {
//Backbone.DeclarativeViews.clearCache();
var itemView = new this.ItemView( { model: model } );
itemView.render();
this.itemViews.push( itemView );
els.push( itemView.el );
}, this );
// Measure itemView creation time
performance.measure( "create-itemViews", "create-itemViews-start" );
duration = performance.getEntriesByName( "create-itemViews" )[0].duration;
this.$el.append( els );
this.$el.appendTo( this.$parent );
// Measure render duration time (total from beginning of itemView creation)
performance.measure( "render", "create-itemViews-start" );
renderDuration = performance.getEntriesByName( "render" )[0].duration;
base.eventBus.trigger( "createStats", {
itemViewCount : this.itemViews.length,
duration: Math.round( duration ),
renderDuration: Math.round( renderDuration )
} );
},
destroy: function () {
_.each( this.itemViews, function ( itemView ) {
itemView.remove();
} );
this.remove();
}
} );
return {
ItemView: ItemView,
ListView: ListView
}
} );
// plain.js
require( [
'local.base',
'local.views-backbone'
], function ( base, backboneViews ) {
var count = 1000,
ItemView = backboneViews.ItemView.extend( {
template: "#item-template"
} ),
listView = new backboneViews.ListView( {
template: "#list-template",
parent: ".container",
ItemView: ItemView,
collection: base.Collection.create( count )
} );
new base.StatsView();
listView.render();
} );
define("local.plain", function(){});
Output
You can jump to the latest bin by adding /latest
to your URL
Keyboard Shortcuts
Shortcut | Action |
---|---|
ctrl + [num] | Toggle nth panel |
ctrl + 0 | Close focused panel |
ctrl + enter | Re-render output. If console visible: run JS in console |
Ctrl + l | Clear the console |
ctrl + / | Toggle comment on selected lines |
ctrl + ] | Indents selected lines |
ctrl + [ | Unindents selected lines |
tab | Code complete & Emmet expand |
ctrl + shift + L | Beautify code in active panel |
ctrl + s | Save & lock current Bin from further changes |
ctrl + shift + s | Open the share options |
ctrl + y | Archive Bin |
Complete list of JS Bin shortcuts |
JS Bin URLs
URL | Action |
---|---|
/ | Show the full rendered output. This content will update in real time as it's updated from the /edit url. |
/edit | Edit the current bin |
/watch | Follow a Code Casting session |
/embed | Create an embeddable version of the bin |
/latest | Load the very latest bin (/latest goes in place of the revision) |
/[username]/last | View the last edited bin for this user |
/[username]/last/edit | Edit the last edited bin for this user |
/[username]/last/watch | Follow the Code Casting session for the latest bin for this user |
/quiet | Remove analytics and edit button from rendered output |
.js | Load only the JavaScript for a bin |
.css | Load only the CSS for a bin |
Except for username prefixed urls, the url may start with http://jsbin.com/abc and the url fragments can be added to the url to view it differently. |