Marionette.js
The Backbone Framework
Marionette v5
TODO# Update documentation
About Marionette
Marionette is a composite application library for Backbone.js that aims to simplify the construction of large scale JavaScript applications. It is a collection of common design and implementation patterns found in applications.
Documentation
All of the documentation for Marionette can be found at
marionettejs.com/docs/current
App Architecture On Backbone's Building Blocks
Backbone provides a great set of building blocks for our JavaScript applications. It gives us the core constructs that are needed to build small apps, organize jQuery DOM events, or create single page apps that support mobile devices and large scale enterprise needs. But Backbone is not a complete framework. It's a set of building blocks. It leaves much of the application design, architecture and scalability to the developer, including memory management, view management, and more.
Marionette brings an application architecture to Backbone, along with built in view management and memory management. It's designed to be a lightweight and flexible library of tools that sits on top of Backbone, providing the framework for building a scalable application.
Like Backbone itself, you're not required to use all of Marionette just because you want to use some of it. You can pick and choose which features you want to use. This allows you to work with other Backbone frameworks and plugins easily. It also means that you are not required to engage in an all-or-nothing migration to begin using Marionette.
Chat with us
Find us on gitter.
We're happy to discuss design patterns and learn how you're using Marionette.
Key Benefits
- Scalable: applications built in modules with event-driven architecture
- Sensible defaults: Underscore templates are used for view rendering
- Easily modifiable: works with the specific needs of your application
- Reduce boilerplate: for all views, including specialized types
- Create: application visuals at runtime with
Region
andView
objects - Nested:
View
s andCollectionView
s within visual regions - Built-in: memory management and zombie-killing for
View
s,CollectionViews
a andRegion
s - Event-driven architecture: utilizing
Radio
- Flexible: "as-needed" architecture allowing you to pick and choose what you need
- And much, much more
Source Code and Downloads
You can download the latest builds directly or visit the downloads section on the Marionette website for more downloading options.
MarionetteJS.com
NPM and Bower
Marionette is available via npm:
# NPM npm install marionette
Release Notes And Upgrade Guide
Changelog: For change logs and release notes, see the changelog file.
Upgrade Guide: Be sure to read the upgrade guide for information on upgrading to the latest version of Marionette.
Annotated Source Code
The source code for Marionette is heavily documented. You can read the annotations for all the details of how Marionette works and advice on which methods to override.
View the annotated source code
Compatibility and Requirements
MarionetteJS currently works with the following libraries:
- jQuery v3.5.1+
- Underscore v1.11.0+
Marionette has not been tested against any other versions of these libraries. You may or may not have success if you use a version other than what is listed here.
How to Contribute
If you would like to contribute to Marionette's source code, please read the guidelines for pull requests and contributions. Following these guidelines will help make your contributions easier to bring into the next release.
Github Issues
Report issues with Marionette, submit pull requests to fix problems, or to create summarized and documented feature requests (preferably with pull requests that implement the feature).