| By Charles Jolley | Article Rating: |
|
| August 18, 2009 04:30 PM EDT | Reads: |
1,300 |
One of the coolest parts of the new SproutCore View layer is its ability to use aspect-based programming to add behaviors to views.
Aspect-based programming is built on the premise that often objects that don’t follow from the same class hierarchy may in fact need similar behaviors.
This is especially true in GUI programming when designers come to you and say something like “I came up with this new widget - it looks kind of like a progress bar but it acts like a button when you click on it”.
In SproutCore, you capture these common behaviors in a “mixin”. A mixin is just a collection or properties and methods that are added to your class when you define it. The view layer will actually look for specific hooks on your mixin so that you can automatically hook into the drawing engine, listen for events, etc. It’s very powerful.
Take the example above: with the button-y progress bar. SproutCore has an SC.Button mixin that implements button-like behavior. Just apply it to an SC.ProgressView and update a few hooks to get the API you want.
MyApp.ProgressButton = SC.ProgressView.extend(SC.Button, {
// ... extra properties here
});
SproutCore comes with built in aspects that implement most of its common APIs including managing content properties (SC.Control, SC.ContentDisplay), rendering (SC.Border, SC.Shadow), and some behaviors (SC.Button).
Over time I expect we’ll add more. In the mean time, this is a great technique to learn to rapidly build high-quality views with composite behaviors without having to rewrite code.
If you want a further example of how mixins can be used, take a look at this tutorial by FrozenCanuck on using the SC.ContentDisplay mixin to easily auto-render a bunch of properties on a content object.
Read the original blog entry...
Published August 18, 2009 Reads 1,300
Copyright © 2009 SYS-CON Media, Inc. — All Rights Reserved.
Syndicated stories and blog feeds, all rights reserved by the author.
More Stories By Charles Jolley
Charles Jolley is the creator of SproutCore and CEO of Sproutit, which provides consulting and software services for building SproutCore applications on the web. He has helped build some of the most popular RIAs on the web today.
- Moving Your RIA Apps into the Cloud: Seven Challenges
- Cloud Computing Drives Real World Enterprise IT Value
- Big Data Kills 30-Year-Old Market
- Revolutionizing Security Through Virtualization
- What Could You Do With Your Code in 20 Lines or Less?
- The Seven Deadly Sins of Software Test Automation
- CenterPoint Energy's Pipeline Group Signs Joint Development Agreement With Affiliate of FPL Group to Explore Construction of New Pipeline in North Louisiana
- The Cloud Bubble: Is Computing Becoming a Utility?
- Moving Your RIA Apps into the Cloud: Seven Challenges
- Pixamba CEO Launches Stock Photography Topic on Ulitzer
- Cloud Computing Drives Real World Enterprise IT Value
- Big Data Kills 30-Year-Old Market
- Animation Doesn't Always Require a Computer
- Revolutionizing Security Through Virtualization
- You Don’t Know Your Competition…
- What Could You Do With Your Code in 20 Lines or Less?
- The Seven Deadly Sins of Software Test Automation
- CenterPoint Energy's Pipeline Group Signs Joint Development Agreement With Affiliate of FPL Group to Explore Construction of New Pipeline in North Louisiana
- The Top 250 Players in the Cloud Computing Ecosystem
- Red Hat Named "Platinum Sponsor" of Virtualization Conference & Expo
- An Introduction to Ant
- Telco Perl Powers Telephony With Linux
- Cloud Computing Bootcamp May 18-19 in Prague, Czech Republic
- This Man Should Be Fired from His Job as a Magazine Editor
- 120 Billion Web Pages Indexed by Cuil
- Microsoft Reorgs After Key Exec Bolts
- Java for Managers -- What Should They Know?
- The Cloud Bubble: Is Computing Becoming a Utility?
- RightScale Goes Multi-Cloud
- ActiveState Celebrates 20th Anniversary of Perl with Release of ActivePerl 5.10.0 Build 1001











E-Government initiatives aimed at modernizing...






















