Javascript code in ASP.NET MVC Partial Views (ASCX) or not?


Javascript code in ASP.NET MVC Partial Views (ASCX) or not?



Is there a "best practice" for placing Javascript code when you have many partial views and JS code that's specific to them?

I feel like I'm creating a maintenance nightmare by having many partial views and then a bunch of independent Javascript files for them which need to be synced up when there is a partial view change. It appears, for maintenance purposes, better to me to put the JS code with the partial view. But then I'm violating generally accepted practices that all JS code should be at the bottom of the page and not mixed in, and also I'd end up with multiple references to the same JS file (as I'd include a reference in each ASCX for intellisense purposes).

Does anyone have a better idea? Thank you!


Passing messages to the user in MVC2

1:

Ninject and repository pattern with interfaces
I don't know if there are many more established "best practises" than the ones you have already stated in your question to which you would like to conform.. ASP.NET MVC 2 website doesn't seem to be picking up code changes Lately i've adopted a Html Helper approach to common js/jQuery blocks this i need for certain complex "controls" this need a lot of ajax and UI js assistance. Disambiguate controller actions of same name based on result type?In my most recent case i had two of these "controls" and each one required 3 script blocks.. ITextSharp saying File not found when published to My server I how have this helper arrangement where i must use syntax like this:. Browser prompting download of JSON response, ASP.NET MVC2
    <%-- // jQuery for Patron --%>     <% =Html.MattyJq().DivListItemSingleSelector("selectPatronItem", "div#matchingPatrons",         "patronsPrevSelectedID","PatronID") %>     <% =Html.MattyJq().EmptyTextInputHelper("patronSearch", "patronsFilterSendEmpty") %>     <% =Html.MattyJq().TextChangeDynamicUpdaterSelect("patronSearch","div#matchingPatrons",         "/patrons/receive patronsitems",500,"patronsFilterSendEmpty","patron",         "patronsPrevSelectedID","selectPatronItem") %> 
I have this "Template" folder in my MVC "/Scripts" folder where i place the script blocks and then mark all the "variables" with an escape sequence such this i must swap/regex in my variables this i had passed into the helpers (above) as params.Dependency injection inside ASP.NET MVC custom model binders and filters This way i must reuse the templates and my views are enough lighter/cleaner. BadImageFormat Exception with Oracle 64 bit client running on Win 7 X64You'll notice common params in the helpers there - that's when, for example, i have js function names or vars this are common to more than one script block. It's a sortof way of "linking" the isolated script blocks toreceive her. Lastly i have a common section for the helpers which enables me to "go over" the resulting js/jQuery with a parser if i choose - in my case i use the .NET YUI Compressor to minify the js in Release builds - i'm sure you could add any logic here to ensure this all the script was at the bottom of the page if you liked..

2:

Use a single JS and unobtrusive javascript to layer on behavior to your html pages. . Throwing js all over the place is such a maintenance nightmare, even with firebug.. Remember, always program as if the person maintaining your code is a violent psychopath. ;).


96 out of 100 based on 61 user ratings 456 reviews

!