<div dir="ltr">On Mon, Jul 22, 2013 at 8:25 PM, Sam Joseph <span dir="ltr"><<a href="mailto:tansaku@gmail.com" target="_blank">tansaku@gmail.com</a>></span> wrote:<br><div class="gmail_extra"><div class="gmail_quote">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
2) similarly: if i have N distinct pages in my app and each has its own quite distinct JS bits, given that the best practice is to combine all the JS and load it all at once and cache it (asset pipeline), is there a best practice for 'inhibiting' setup functions ($(document).ready()) that don't correspond to the 'current' page?  (ie, your setup function might be trying to bind the '#foo' element, but that element only exists on a particular page; do you let the setup function silently fail, or do you arrange to only run that particular setup function if you're on the page containing #foo, or do you condition the function so that it gracefuly fails in the absence of #foo?)<br>

<br></blockquote><div><br></div><div>It can be helpful in many ways to encode the controller name and action name as classes in a high-level element such as <font face="courier new, monospace"><body></font>, giving you, for example:</div>
<div><br></div></div></div><blockquote style="margin:0 0 0 40px;border:none;padding:0px"><div class="gmail_extra"><div class="gmail_quote"><div><font face="courier new, monospace"><body class='orders new'></font></div>
<div><br></div></div></div></blockquote>You can use this to scope css as well as javascript. Continuing your example, you might have:<div><font face="courier new, monospace"><br></font></div><blockquote style="margin:0 0 0 40px;border:none;padding:0px">
<div><font face="courier new, monospace">$(document).ready(function() {</font></div></blockquote><blockquote style="margin:0 0 0 40px;border:none;padding:0px"><div><font face="courier new, monospace">  $('body.orders.new #foo').bind(...);</font></div>
</blockquote><blockquote style="margin:0 0 0 40px;border:none;padding:0px"><div><font face="courier new, monospace">});</font></div><div><font face="courier new, monospace"><br></font></div></blockquote><font face="arial, helvetica, sans-serif">On pages aside from orders new, the function does not fail per se, but it has no effect. You can observe your app to determine whether accumulation of such functions has any meaningful performance impact.</font><span style="font-family:'courier new',monospace"> </span><br>
</div>