The outerspace background is totally the killing the 'rocketship' paradigm. It kills scrolling performance and uses quite a bit of CPU. Then again a rocketship uses tons and tons of fuel so perhaps this is intentional? =)
I really want to like this, but I can't get behind Sprockets when RequireJS and Browserify exist. Code in comments, obtuse file extensions, `require_tree`, etc. make code modularization an inelegant kludge.
Some of the story behind Spar: <a href="http://www.slideshare.net/wyrmwood/ultramodern-frontend-dev-introducing-spar" rel="nofollow">http://www.slideshare.net/wyrmwood/ultramodern-frontend-dev-...</a>
The concept is great. I use Spine.app for this myself.<p>A nodejs stack makes more sense to me because the app itself is powered by JavaScript, not Ruby, and then I am truly decoupled from other languages. However, I can see why someone coming from Ruby would prefer Spar -- even Spine.app includes Sprockets support for Ruby devs.
This is a ridiculous concept and the opposite of "modern" web development, as it purports to be. Maybe I'm using a different definition of "modern" - it seems here that it means "using new shiny things" rather than "using accumulated knowledge of web development patterns to build the best user experience." But, I digress.<p>There is a massive gap here, and with any framework that is purely client-side. Here's what you get if you serve html from the server:<p>* SEO. You can't crawl a page that loads purely over Javascript. Google has an API to allow access to ajaxed-in pages, but that means modifying you code to fit exactly what each crawler needs. Not going to happen.<p>* Better accessibility. Yes, some screen readers handle Javascript now, but many don't.<p>* Page performance. Time-to-usability on a page served by a server is several orders of magnitude faster than when you load javascript, then load data, then render the page. If the server can serve html, you can start using the page while the scripts load and initialize in the background.<p>If performance isn't a big deal, you want to make awkward hacks to force SEO to work, and you don't care about reaching all possible people? Build a single-page-app and nothing else.<p>I'm not saying don't make a single-page app; I'm saying be smart about it.<p>You've got two steps out of three - building an API and a single-page app. The missing middle step is building a second server side app that reads from that API (RESTful, right?) and bootstraps the page, which is built using language-agnostic templates like Mustache. Then, you load your Backbone/whatever JS on top, which takes over, and points at your api. It's easy to do with something like Node that can even share the same code to build pages.