Around nine months ago, I was looking into a potential project for work. In it's simplest form, this project involved building a web application that would mostly be built using JavaScript and that worked on all the major browsers and in particular, it must be viewable on an iPad. So, I set about searching for a JavaScript framework that would support this.
Now I class myself as quite the geek and I like to think that I know of most of the major JavaScript frameworks. JQuery, Dojo, Prototype, etc. On top of that there's a few control libraries such as ComponentArt and Obout which I'm also quite familiar with. I looked into all of these but their functionality and look and feel didn't really jump out at me. I thought I'd do a bit of research and came across a framework that I'd never come across before... Sencha's ExtJS Framework. After spending the past couple of months working nearly exclusively with the framework, I thought it'd be a good idea to share my experience with you people so that if you're in a similar position to me, trying to decide whether or not to use an unfamiliar framework, you have a bit more extra information to go on.
It's worth mentioning that I'm in no way affiliated with Sencha so this is a completely independent review.
So, what do I look for in a good framework? Well, I think there's six categories to look at:
- Functionality - Unsurprisingly, a good framework needs to do what you need it to do. If it doesn't fit your requirements then there's no point in using it.
- Performance - There's not a whole lot of use in having a framework that does everything you need it to if it takes days to do it. How well does it perform?
- Ease of use - I would say I'm proficient in JavaScript. I'm certainly no expert. I expect a framework/library to be understandable and usable by someone with my level of understanding of the language. I do not want to have to take a two month extensive course in the inner workings of JavaScript in order to use the thing.
- Documentation - Any and every good framework/library needs to have good documentation. You don't want to be stepping through code to work out how to render something. It's much more effective to look up the documentation, have a quick read and then away you go.
- Extensibility - The chances are that at some point during your development cycle, you're going to need to add to the framework in order to achieve your desired functionality. How easy is this to do?
- Support - Sometimes you just can't work something out, is the support out there to help you through these difficult times?
Functionality
ExtJS has the most extensive functionality of any JavaScript framework I've ever come across. It has the ability to create some great user interfaces with some great special effects. Want pictures flying across the screen? No problem. Want something to fade in or out? Easy. And that's just for starters. It has a whole charting module: bar, line, graph, area, scatter, radar charts can all be created with minimal fuss. Along side that you've got grids which automatically support sorting, paging, editing and grouping.
Charts and graphs is only a small piece of ExtJS functionality |
On top of all the controls, there's the functionality that the controls themselves bring to the table. Bar charts can just be rendered, or, you can animate them so they bounce in to position. Want to show a legend? No problem, that's in there too. Just about every time I've thought "I wonder if I can do x, y and z", I have a look and low and behold the framework supports it. It really is a very impressive framework.
Performance
With the amount of functionality that ExtJS does provide, performance is always going to be a talking point, especially when so much relies on manipulating the DOM which we all know can be slow. Now I've used ExtJS 4.0 extensively and I must say that the performance is very good. Like any programming library, there's way in which you can optimize your code so that you get the most out of it and I believe that if you do optimize then you'll be very impressed with its performance.
Performance of ExtJS4.0 is impressive! |
Ease of Use
ExtJS is exactly what I'd expect a good JavaScript framework to be in terms of ease of use. I simply picked it up and started to play around with it and soon got to grips with its functionality and how it can be used. Sencha provide loads of good examples ranging from the basic to the more advanced. All of their examples have their source code attached, you can simply look at the source code and work out what's going on. All of the objects and functions are logically named so the code is easy to follow. Put that together with a modern browsers JavaScript debugging capabilities and you can work out exactly how everything works and from there you can work out how to adjust the code to suit your needs.
If that isn't good enough, Sencha also provide well written tutorials on how to use the framework and how to deploy it, making it as simple as possible. If you want to check those out then have a look here.
Documentation
Documentation is a must for any framework |
You'd think this is one area that all frameworks would do well in, after all, documenting is just a case of writing down what everything does. You'd expect framework providers, especially ones that charge for use, would devote time to this area. However, you'll be surprised how poor the documentation is out there. jQuery is a framework that I've had a fair amount of experience with and they're pretty good with documentation, in contrast, I've also had a lot of experience with ComponentArt and they're documentation is absolutely shocking. I've wasted hours of my life trying to figure out how to use ComponentArt controls or trying to find out exactly what a certain property/method does because the documentation just simply doesn't tell you. Nine times out of ten, it's either non-existent or incomplete. You have no idea how much of a difference comprehensive documentation makes when you're trying to use a new framework.
Extensibility
Almost every time I've had to use a framework, it never quite works as I need it to so I end up modifying the source code or ideally, I build on top of the framework to add a bit of functionality to it. ExtJS recognises this and provide ways for you to override and extend objects. The framework heavily relies upon inheritance so extending and overriding controls is a very familiar concept for programmers that use object oriented concepts on a day to day basis.
Support
No matter how easy a framework is to use and no matter how good their documentation is I can guarantee at some point or the other you will come across a problem that you're struggling to solve. At this point you'll want to ask the wider world for a bit of help. Sencha have specific forums for this and for a fee you can access specific forums that are monitored by Sencha developers. ExtJS is fast becoming a widely used framework so, if you post a problem on a well known forum (say StackOverflow for example) then you'll be almost guaranteed a reply.
So... In Conclusion....
I think it's pretty fair to say that I'm a massive fan of the framework. This has blown frameworks that I have previously used out of the water. Some of the things I've managed to build in a day would have taken me months without the use of the framework. The documentation and general ease of use make developing applications with the framework a simple and effective task and because of the sheer quality of documentation, you feel your productivity increases just by using it. The thing I like the most... and this sounds kind of odd but, it just works. The quality of coding is very high. I've been using the framework on and off now for about nine months and I can count the number of problems I've come across on one hand and even then, I've been able to solve them with minimal effort.
It's not all good though, as I've stated previously, there is one big downside... upgrading and backwards compatibility. I upgraded from 4.0 to 4.1 and everything, and I do mean everything, broke. When I eventually got things working again the performance was so bad that I had to revert everything and stick with 4.0. I don't seem to be the only person that's had problems either. If you want to have a look for yourself, then you can check out the comments to Sencha's blog post about the 4.1 release here. Here's one comment that jumped out and me and summed up my frustration after a couple of days of trying to get things working after the upgrade:
"What a shocking release. An app that works without fault in 4.0.7 doesn't even show up properly in 4.1. We just got Sencha'd ... again!"
But that's the only fault I can find. If you're not worried about backwards compatibility and if the framework in its current state does what you need then I couldn't recommend it higher. It truly is a fantastic framework to work with. Just don't try upgrading.
i dont think documentation is good. just providing all the methods that a particular component uses aint good. sometimes there are dead ends where they tell you that an objects needs to be passed and ultimately youll have to revert to google to understand the actual structure of the object
ReplyDeletePersonally, I think that's being a little harsh. Each and every control not only has documentation on all it's properties/methods, it also has examples with live demo's on how to use the thing.
ReplyDeleteHave you got an example of a "dead end" method that I can take a look at?
Ext JS and Touch are frameworks. Not libraries you sprinkle in. You need to take the time to learn them like you would any other framework e.g. rails, .Net, etc ... If you give it that respect to try it for more than a few hours I think the return on investment is quite worth it.
ReplyDeleteNo documentation is perfect but Sencha is setting the bar when it comes to framework documents especially when compared to other javascript libs.
Finally know that until you start reading and making sense of the internals of the framework. Things can and will be mysterious. The instant you learn you can discover how things work by simply viewing the source to see what's going on, the game changes. This makes upgrading much simpler as when things break you can peer in and find out what changed and what needs to be done. I won't argue that you shouldn't have to do that, I agree you should not.
I build Sencha Architect (on Ext JS) http://www.sencha.com/products/architect
I am a little biased but I've only been part of Sencha for 1 year and have used them for over 1/2 a decade.
Thanks for all the kind words.
ReplyDeleteI'd love to hear more details about your upgrade experience from 4.0 to 4.1. Obviously we changed a lot of internals in that release and tried to ensure compatibility where we could, but if you wanted to comment on some specifics I'd really appreciate hearing about it.
I certainly can.
ReplyDeleteOff of the top of my head I remember changes having to be made to get drag and drop functionality that worked perfectly in v4.0 to work at all in v4.1.
The other problem I had was performance. The application dynamically adds controls (form controls, charts, images, just about any sort of control that ExtJS supports) to various panels contained inside a viewport. The load time for the application was around 10-15 seconds. When I moved to 4.1 that significantly shot up into the 40-50 second bracket. I did briefly try and optimize it to improve this by using the new Ext.suspendLayouts and Ext.resumeLayouts methods but the decrease from that was around 10-15 seconds, which made the overall load time still significantly slower than v4.0.
There were other things as well, I just can't remember them off of the top of my head but if you're interested, if you drop me an e-mail (GAClements@outlook.com) then I'll do the upgrade again and note the problems as I come across them and I'll forward the problems I come across on to you.
Thanks.
I don't think it has good documentation.
ReplyDeleteDocumentation give only simple examples.This is ok for small demos.
For the complex queries in existing developed big project can not be resolved with these docs.
Also we can develop small examples very quickly, but for big projects, not so easy go. Coding style is not clean... it is much complicated.
I'm a long time user of Ext JS but recently have been trying to replace it with some other framework. My reasons are:
ReplyDelete- ExtJS is ugly (or just dull). GUI design looks quite dated and few exisiting themes don't improve the situation.
- ExtJS doesn't cooperate well with plain HTML and with other CSS frameworks.
- can't understand their MVC idea. Don't want to write single page applications, I want to keep more logic on the server, not in javascript
But, after evaluating several other frameworks and combinations of them, i came to conclusion that it's impossible to have everything that ExtJS has, there's no framework that would be so complete and consistent, and trying to glue several other libraries is a total waste of time. So i think i'll have to tolerate ugliness of extjs for some more time.
And BTW, ExtJS is very good compared to other popular javascript frameworks
Delete