Skip to content

An example Rails app showing how to integrate Sprockets with a Node asset pipeline.

License

Notifications You must be signed in to change notification settings

spikebrehm/sprockets-node-example

Repository files navigation

Sprockets-Node Example

An example Rails app showing how to integrate Sprockets with a Node.js-based asset pipeline, using Browserify.

Installation

First, clone the repo somewhere locally:

$ git clone git@github.com:spikebrehm/sprockets-node-example.git

Then, run bundle install and npm install to install Ruby and JavaScript dependencies:

$ bundle install
$ npm install

Now you should be able to to run the Rails server:

$ rails server

Check out the app running at http://localhost:3000.

Usage

This Rails app is a simple implementation of the TodoMVC Backbone app.

screenshot

We've implemented two different versions of the TodoMVC Backbone app:

  1. The default TodoMVC code, using Sprockets to manage the JavaScript assets (http://localhost:3000).
  2. The TodoMVC code refactored to use CommonJS to manage the JavaScript assets (http://localhost:3000/commonjs).

How it works

Tilt Template

We built a custom Tilt template to handle the file extension .bundle.js, which we'll use to indicate CommonJS bundles. We've called our Tilt template BrowserifyTemplate, and it lives at lib/browserify_template.rb.

Browserify commandline script

The BrowserifyTemplate shells out on the commandline to a Node.js script that takes the path to a .bundle.js file, calls Browserify, and returns the output as STDOUT. See script/assets/tasks/bundle.js.

$ ./script/assets/tasks/bundle.js --path app/assets/javascripts/commonjs/manifest.bundle.js

BrowserifyTemplate captures the STDOUT output and hands it back to Sprockets to manage.

About

An example Rails app showing how to integrate Sprockets with a Node asset pipeline.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published