My Secret Life as a Spaghetti Coder
home | about | contact | privacy statement
Asking the right question
This post relays some wisdom from Scott Davis's keynote speech at NFJS in Austin a little over a month ago. The talk was titled, "No, I Won't Tell You Which Web Framework to Use... (or The Truth, With Jokes)."

He talked about a lot of different things, but the point of the talk didn't really have anything to do with web frameworks, or computers in general. It was about choice, markets, crowds, and questions. It can be applied easily to the software we build, but it can also be applied equally to other things in general. Well, at least that's what I came away with.

Scott first explained why asking "which web framework should I use?" is virtually pointless. How do I know what framework you should use? I don't know what you're looking for in it. I don't know what you need it to do. Answering what you should do based on my needs is "outside my realm of expertise." All of them work, so "every framework out there is potentially the 'right one.'"

Instead, you should ask me "what framework do you use" or even better, "why do you use the framework that you do?" Here he actually related it to cell phones, but I'll stick with the web framework theme. In fact, you could replace web framework with

            x, where x ∈ UsableNouns

and it would still make sense.

Choose? I've got too many stinking options!
At this point Scott started to explain analysis paralysis and brought up a new book to put on my to-read list: The Paradox of Choice: Why More Is Less.

He told a story (I believe to be from the book) that succinctly showed what happens when consumers are presented with too many choices: Given 3-5 options for tasting Jellies/Jams, customers ended up buying more of it. However, increasing that to two-dozen left sales at levels lower than having no sampling at all.

We simply become overwhelmed by the number of options available, turn off, and refuse to make a choice at all. That leads us to the Maximizer/Satisficer concept, where the Maximizers are especially prone to analysis because they try to be more prepared when making decisions and never stop analyzing, even after making the choice. On the other hand, satisficers try to narrow their decision-making points down to a reasonable few.

The existence of analysis paralysis doesn't "mean that we should limit the number of frameworks that can be legally created." Instead, we should try to be like the satisficer and "limit out decision criteria to 3-5 important attributes."

So which framework should I use?
Consider "Plain Old HTML." As Scott noted, "Nothing will scale better, nothing is easier to deploy, [and] nothing is better supported across all vendors, servers, platforms, languages..." Even without all that, "it forces you to identify what features you really need." That, according to Scott, is the most important reason to use plain HTML. In any case, make sure you stick to standards so you can switch easily.

But the interesting part for me was not his discussion of web frameworks - it was the books he mentioned while making his points (more to put on the to-read list!). Therefore, I'll focus more on that aspect.

Scott brought up Struts - and while one might use The Wisdom of Crowds to justify its use, you might also notice its complexity is reminiscent of an older era and the leaders of the movement have moved on to other things. It is past Struts 1.x time.

Struts 2 is out now, but it has thus far failed to reach The Tipping Point. On the other hand, Ruby on Rails illustrates the qualities of the tipping point: virally contagious, "dramatic and immediate" effect, not "slow and steady." It shows how "tiny 'tweaks' to a proven model can yield big, disproportionate effects." By introducing the concepts of convention over configuration, scaffolding, and "opinion-oriented software" to the traditional MVC approach, Rails hit the tipping point.

When to adopt new technology
Aside from narrowing your decision points and using the heuristic of the wisdom of crowds, Scott introduced the Gartner Hype Cycle, the O'Reilly Curve, and yet another book to go on my reading list, Crossing the Chasm to help explain the tipping point and give something to consider as to when you might want to adopt a new technology.

The Gartner Hype Cycle
The Gartner Hype Cycle (Image from Tom Murphy @ Global PR Blog Week)

Gartner explains the Gartner Hype Cycle well enough, so I'll leave it to you to learn from the source.

The O'Reilly Curve
The O'Reilly Curve (Image from Scott Davis's presentation slides - Couldn't find it online Online here)

The O'Reilly Curve (as near as I can tell) was invented by Doug Kaye of IT Conversations. Basically, the idea is that "publication of an O'Reilly book signals a transition of that technology from 'innovation' to 'early adopter' phase."

Update: Thanks to Doug, you can read a full discussion about the O'Reilly Curve at his blog.

As you can see in the graph above, there are many stages to technology adoption. Although you may want to be an early adopter to increase your chance of success, you can see that you don't achieve return on investment (as an organization) until after there are experienced staff available to work in the new technology.

Before that, you have some lead-time that can bring you competitive advantage.

So when is the best time to move in? If I recall correctly, Scott mentioned the same as Doug Kaye- when O'Reilly publishes a book. That gives you enough resources to be successful, and enough lead-time to be ahead of competitors. Of course, your acceptable level of risk and values will vary, so your choice ultimately comes down to the type of person you are or organization you work in (also explained in Gartner).

As our final heuristic, we can look at the chasm and ask ourselves, "Has the technology crossed it yet?"

Crossing The Chasm
Crossing The Chasm (Image from the book, I believe)

Thinking about these things is not only useful from a technology perspective, but from a sales and marketing business perspective for your own products, which is what interests me more about them. (I don't have much experience in those areas, which is why I'm putting these books on my to-read list.) Because of that, I'll remain otherwise silent on the issue, only noting that you needn't look at them from one perspective.

"You know that thing you think is a duck? Well I think it's a rabbit."
Scott said something like that when he began a discussion of paradigm shifts, noting that Rails and Grails are "still fundamentally page-centric MVC frameworks." On the other hand, JSF, Seam, and Tapestry are based on the idea of component-widgets and are much more in line with the Web 2.0 paradigm shift. (The book from this section that goes on my to-read list is The Structure of Scientific Revolutions, which talks about paradigm shifts in science.)

Bringing it all together
You should be convinced that asking what framework you should use is a poor question. You should be asking what other people use and "why?" As Scott reiterated at the end of his presentation, "I can't tell you which filters to apply" when making your decision. But the key is found in "thin-slicing" (from the final book I'll link to today, Blink: The Power of Thinking Without Thinking).

Thin-slicing is the act of "filtering on the few factors that matter" while "ignoring the overwhelming number of others." Sound familiar? It should.

The point is that when making a choice about something, be it technology or otherwise, you need to consider only what is relevant. Pick a few features you need, pick a level of adoption or risk you're willing to handle, and consider shifting paradigms (will the well established still be around?). Ask someone what they use and why they use it. Then, when you've narrowed the field of consideration to something manageable, you can make your choice.

So, what framework I should use?

Hey! Why don't you make your life easier and subscribe to the full post or short blurb RSS feed? I'm so confident you'll love my smelly pasta plate wisdom that I'm offering a no-strings-attached, lifetime money back guarantee!


Comments
Leave a comment

Hi, Sam. Yes, the O'Reilly Curve is my invention, first published on my blog in 2002:
http://www.rds.com/essays/20020414-when.html

Posted by Doug Kaye on Aug 13, 2007 at 04:08 PM UTC - 5 hrs

Thanks Doug. I've updated the post accordingly so it's found a bit easier.

Posted by Sam on Aug 13, 2007 at 09:48 PM UTC - 5 hrs

"On the other hand, JSF, Seam, and Tapestry are based on the idea of component-widgets and are much more in line with the Web 2.0 paradigm shift."

No, I dont think so. Web 2.0 is about REST-centric. Component-based framework try to be desktop-alike environment. It is not web-oriented.

Posted by pcdinh on Aug 14, 2007 at 04:36 AM UTC - 5 hrs

pcdinh- Thanks for the valuable comment. Let me ask you some more questions and raise some more points below.

Is what we mean by Web 2.0 just that it is "REST-centric?" I think that's certainly part of it, but what about the ideas of community and Ajaxification? There are probably others, but those are 3 that are on the top of my head. In fact, I would have thought being REST-centric was a relatively minor item.

In any case, my thought is that the other two I mentioned are also large parts of the paradigm shift to Web 2.0, and componentization (can I call it that?) plays well idea-wise with Ajax. In other words, now we might think of widgets talking back and forth with the server rather than thinking in terms of pages.

I know the idea of component-based frameworks was to try to be like desktop programming - insulating you from the underlying fact you are on the web - but I don't see how that is fundamentally different from thinking in terms of components instead of pages.

Of course, I've yet to use those frameworks, so I'm really just basing that on semantic understanding of the words chosen to represent the technology, not on any deep understanding of the frameworks themselves.

Thoughts?

Posted by Sam on Aug 14, 2007 at 08:53 AM UTC - 5 hrs

I think that there is no relationship between component based frameworks and Web 2.0 at all. Maybe they are both popular these days, but their development has been independant from each other.
In my opinion JSF was surprised by the success of AJAX and would look quite different if the commitee had AJAX support during development in mind .

Posted by Anon on Aug 14, 2007 at 06:37 PM UTC - 5 hrs

@Anon - It may be that there is no relation between the two. I'll defer to your judgment since I haven't used a component based framework. =)

But I will point out that simply because their respective developments have been independent is not cause to believe they are not part of the same movement/paradigm shift. In fact, I think if we look at history most such shifts in thinking have occurred by independent actors in a given time frame.

Such shifts occur when we take into account many different developments that change our attitudes and beliefs.

Posted by Sam on Aug 15, 2007 at 10:40 AM UTC - 5 hrs

Leave a comment

Leave this field empty
Your Name
Email (not displayed, more info?)
Website

Comment:

Subcribe to this comment thread
Remember my details
Google
Web CodeOdor.com

Me
Picture of me

Topics
.NET (19)
AI/Machine Learning (14)
Answers To 100 Interview Questions (10)
Bioinformatics (2)
Business (1)
C and Cplusplus (6)
cfrails (22)
ColdFusion (78)
Customer Relations (15)
Databases (3)
DRY (18)
DSLs (11)
Future Tech (5)
Games (5)
Groovy/Grails (8)
Hardware (1)
IDEs (9)
Java (38)
JavaScript (4)
Linux (2)
Lisp (1)
Mac OS (4)
Management (15)
MediaServerX (1)
Miscellany (76)
OOAD (37)
Productivity (11)
Programming (168)
Programming Quotables (9)
Rails (31)
Ruby (67)
Save Your Job (58)
scriptaGulous (4)
Software Development Process (23)
TDD (41)
TDDing xorblog (6)
Tools (5)
Web Development (8)
Windows (1)
With (1)
YAGNI (10)

Resources
Agile Manifesto & Principles
Principles Of OOD
ColdFusion
CFUnit
Ruby
Ruby on Rails
JUnit



RSS 2.0: Full Post | Short Blurb
Subscribe by email:

Delivered by FeedBurner