I am trying to convert an existing app to the new 3.1 asset pipeline layout, and want to include a lot of vendor files that have to be in a specific order, (underscore.js an
I believe you can put a library.js
in your in vendor/assets/javascripts
and then simply
//= require library.js
from your application.js
, no?
You can require each file in particular order and then add:
//= require_self
instead of:
//= require_tree .
You have two possible structure : the first one and the second one.
With both following examples, you expose a package at /assets/externals.js
.
You can javascript_include_tag
this package, but you can also require it in your application.js
file.
vendor/
├── assets
│ ├── javascripts
│ │ ├── externals.js
│ │ ├── modernizr-1.7.js
│ │ └── underscore-1.1.6.js
│ └── stylesheets
└── plugins
The file externals.js
contains :
//= require ./underscore-1.1.6.js
//= require ./modernizr-1.7.js
vendor/
├── assets
│ ├── javascripts
│ │ └── externals
│ │ ├── index.js
│ │ ├── modernizr-1.7.js
│ │ └── underscore-1.1.6.js
│ └── stylesheets
└── plugins
The file index.js
contains :
//= require ./underscore-1.1.6.js
//= require ./modernizr-1.7.js
My answer applies to Rails 3.1rc4, I don't know whether it functions the same with other versions.
You can actually put all require statements in app/assets/javascripts/application.js whether or not the .js files are in app/assets/javascripts/ or vendor/assets/javascripts/
Like so:
// this is in app/assets/javascripts/application.js
//= require modernizr-2.0
//= require jquery
//= require jquery_ujs
//= require jqueryui-1.8.12
//= require jquery.easing-1.3
//= require jquery.noisy
//= require jquery.jslide-1.0
//= require respond
//= require smoke
//= require_tree
I included require_tree here because I have other javascript files for my individual controllers (pages.js.coffee, users.js.coffee) and a general one for site-wide stuff (site.js.coffee)
Meanwhile here's the file structure.
app/
├── assets
│ ├── javascripts
│ │ ├── application.js
│ │ ├── pages.js.coffee
│ │ ├── users.js.coffee
│ │ └── site.js.coffee
│ └── stylesheets
└── plugins
vendor/
├── assets
│ ├── javascripts
│ │ ├── jquery.easing-1.3.js
│ │ ├── jquery.jslide-1.0.js
│ │ ├── jquery.noisy.js
│ │ ├── jqueryui-1.8.12.js
│ │ ├── modernizr-2.0.js
│ │ ├── respond.js
│ │ └── smoke.js
│ └── stylesheets
└── plugins
This allows me to control the load order of vendor libraries (which matters a lot, usually) and not worry about my internal javascript, where order generally matters less.
More importantly, I control all require statements within one often used file, I find that both safer and cleaner.
require_tree does exactly what you tell it. If you give it
//= require_tree .
it loads the files in the current directory where require_tree is called. If you give it
//=require_tree ../../../vendor/assets/javascripts
then you'll get the javascript under vendor.
I did not like the ../../.. notation, so I created a file called vendor/assets/javascripts/vendor_application.js which contains:
//= require_tree .
That loads the javascript under the vendor directory.
Note, require does search the 3 pipeline locations (app, lib, vendor) for the file to require. require_tree is literal, which is probably the way it should be.
The railscast on this is very helpful: http://railscasts.com/episodes/279-understanding-the-asset-pipeline