I have a e-commerce website, and it is a little JavaScript intensive (conditional filtering for price, brands, etc. AJAX calls, etc.). I have a lot of cluttered JavaScript/jQuery code on my website (views not separate, no reusability, etc.), and we're planning to rewrite the code.
To solve the problem, I came across KnockoutJS
, and on further research, Backbone.js
, AngularJS
, Ember.js
, etc.
I looked at most of the popular websites, like SO, GitHub, Amazon, Ebay, etc. and it seems none of these websites use any of these frameworks.
What I cannot seem to figure out is the use case for using these frameworks. The wikipedia pages suggest these are designed for single page apps.
- Is it worth the effort to implement the above for a traditional e-commerce website?
- Are there any downsides to using any of the above frameworks ?
- Is there a reason why a lot of popular websites are not using them ?
I work for some bigger company as javascript developer. We have about 30 web projects. But we don't use any MV* for javascript.
1) I think that it doesn't worth till you have only few javascript developers. It is better to have set of widgets and reuse widgets from this set. Each widget is an object in our case. Javascript is mainly view so why to separate it into more parts?
2) The main downside is that you are trying to use too big hammer, so it extends development time. Filtering, searching, sorting, ajax and other stuff are very common and simple problems. You don't need MV* patterns for these.
3) Supranational organizations can afford it. Also you can find it in some webGL projects (games) and similar things. Others don't need it.
Also don't forget that "premature optimization is the root of all evil". Good frameworks and clear code can help you in the future, but it can also stop you in the present!
These frameworks are designed to make your code easier to maintain and to improve the user experience by creating single page applications, in this kind of apps the navigation is more fluid because everything is loaded via AJAX if you want to learn more about it you can start with http://en.wikipedia.org/wiki/Single-page_application.
Another advantage of this sort of applications is that you are going to need an HTTP API to be the access point to your data access layer (DAL) from the front end. When you have a HTTP API your DAL is 100% independent of the data presentation layer this means that in the future you will be able to re-use it to create other apps like for example mobile apps, you can even use tools like phone gap to auto generate the mobile apps for you if you follow this approach.
You can also save a really big amount of time auto-generating your HTTP API by using tools like http://deployd.com/. So we can say that following this approach provides a better user experience, is faster to develop and easier to maintain and test that's why it is so popular. Big companies like Google (angular.js) and twitter (https://github.com/twitter/flight) are using it but they just created their own one.
If you find complicated to decide what framework to use take a look to http://todomvc.com/ they provide with the same example (a TODO application) in each of the available frameworks so you can pick the one that you like more.
Hope it helps :)