I was recently evaluating the different frameworks for developing mobile web apps. I created an app in Sencha Touch, jQuery Mobile and JQTouch.(I also did a responsive web site using media queries, but this isn't so much a framework.) Here is my summary.
Sencha Touch is very different than anything I have used before. All of the content of the web app is built with JS. You code everything with JS. This causes things to be a bit janky, especially on older smart phones that need more time to process all that script. The biggest drawback, however, is that the online documentation is very difficult to use, especially for newbies. They have a few video tutorials online, but some are outdated and many are inconsistent (some use MVC architecture, for instance, which really throws you off if every other tutorial doesn't). All-in-all, if you are a web developer by trade and are used to manipulating DOM-level elements, this is a very frustrating framework to try to learn. Be ready to spend a serious amount of time on the learning curve. (Also, you have to pay Sencha if you want the latest and greatest version of their framework.) After attempting a few different projects with Sencha Touch over months, I grew frustrated and threw in the towel, even outsourcing the remainder of one project to India.
jQuery Mobile is well documented and has plenty of example code for you to follow along. You develop your web app as you would a website and use different data-xxxx attributes on HTML objects to describe how objects should be styled or used. Once you have your structure, jQuery Mobile takes care of the rest, making everything look nice and employing fancy animated screen transitions. There is a small learning curve when getting started, nothing compared to Sencha Touch. And last but not least, jQuery Mobile is FOSS and appears to be in very active development. I was very happy with the example projects I put together with jQuery Mobile. They were easy to finish and worked well.
JQTouch, when I evaluated it, didn't appear to be in active development. The documentation was a little sketch and I found the demo/example code and the documentation disagreed on how things should be implemented. It took some trial and error to find out which methods were correct. I wouldn't recommend this framework for development unless they have taken great strides in recent months.
I want to mention responsive web design because it has great potential. While it doesn't give you the web app feel and isn't really a web app framework, it is definitely a good way to go if you need to develop a mobile web site. The pages load faster than they would using a web app framework (there is much less styling and JavaScript in the background). On the flip side, there are no fancy transitions, but that can be a good thing. You are in control of all the styling and the size of all the UI elements. Plus when designed right, it works on screens of all sizes -- there is no need for special mobile sub-domains or redirects.
In the end, no web app framework is perfect and completely replicates the native experience -- that hasn't happened, yet. With this said, I recommend jQuery Mobile and responsive web design as my favorites. They are different solutions for different problems (jQuery Mobile for a native-app experience, responsive for informational sites), but I would strongly suggest evaluating them if you have a new mobile web project coming up.
 
 
4 comments:
Hi Eric,
Thanks for the informative post. I can't seem to find alot of information out there for app creator software. I am not a developer, etc. Can you recomend something for a lay person who wants to create a mobile app?
Thanks alot,
Kathy
Kathy - I'm not familiar with anything that would be usable by non-developers...
I am finding your comparison of the usability and learning curves for Sencha vs jQuery Mobile to be spot on.
I've been struggling trying to get anything to work past their pretty skeleton example for a week now and just stumbled across jQuery Mobile today and a few hours later have every working and looking nice.
No comparison - at least when trying to make a mobile version of an existing dynamic site rather than a native app.
doug
Have you tried using Sencha Touch 2.0? I found that a lot of the things you mention in your post don't apply anymore.
Their new API docs are much better then the ones for 1.1, and they have written many useful guides both for beginners and more advanced users.
http://docs.sencha.com/touch/2-0/
http://docs.sencha.com/touch/2-0/#!/guide
Also the performance of the applications written in Sencha Touch 2.0 on both Android and iOS seems to be a lot better. I tried writing applications with jQuery Mobile several times and always feel like it is lacking a lot in performance.
Although I agree that jQuery Mobile comes more natural to web developers who are just used to simple DOM manipulation using HTML/CSS, I believe that when writing any serious mobile application, Sencha Touch 2.0 is a much better option, even though it has a slightly higher learning curve.
Post a Comment