Helping you select an MV* framework

TodoMVC

Introduction

Developers these days are spoiled with choice when it comes to selecting an MV* framework for structuring and organizing their JavaScript web apps.

Backbone, Ember, AngularJS… the list of new and stable solutions continues to grow, but just how do you decide on which to use in a sea of so many options?

To help solve this problem, we created TodoMVC - a project which offers the same Todo application implemented using MV* concepts in most of the popular JavaScript MV* frameworks of today.

Examples

JavaScriptCompile-to-JSLabs
  • R = App also demonstrates routing

Real-time


Node.js


Compare these to a non-framework implementation


Todo app screenshot

New in 1.3

  • We now have 64 applications.
  • Updates have been made to apps including Vanilla, Angular, React, Backbone, Ember, jQuery & many more.
  • The knockoutjs_classBindingProvider application has been removed.

Selecting a Framework

Once you've downloaded the latest release and played around with the apps, you'll want to decide on a specific framework to try out.

Study the syntax required for defining models, views and (where applicable) controllers and classes in the frameworks you're interested in and try your hand at editing the code to see how it feels using it first-hand.

Please ensure that if you're happy with this, you do spend more time investigating the framework (including reading the official docs, the source and its complete feature list). There's often a lot more to a framework than what we present in our examples.

Getting Involved

Is there a bug we haven't fixed or an MV* framework you feel would benefit from being included in TodoMVC?

If so, feel free to fork the repo, read our contribution guidelines, and submit a pull request — we'll be happy to review it for inclusion.

Make sure you use the template as a starting point and read the app specification.

Submit Pull Request »