preferisco tirare le URL da un tag 'href o modulo' azione del - o qualche altro elemento che abbia un senso.
<img class="_click" src="<%= Url.Content("~/my/image.png") %>" alt="Click" />
E nella mia javascript (doppio controllo questo su jQuery, io non sono sicuro se è la sintassi esatta.):
var url = $('._click').attr('href');
// To pass these to your plugin as options
// see lightbox source for a full list
$('a').lightBox({ imageLoading : url })
Un'altra opzione leggermente meno preferito è quello di aggiungere le impostazioni in cima il tuo file:
<script type="text/javascript"><![CDATA[
$('a').lightBox({ imageLoading : <%= Url.Content("~/my/image.png") %> })
//]]></script>
Ho detto "meno preferito" perché questo approccio mescola markup e codice.
Un altro approccio (che ha bisogno di un sacco di riordinare) è quello di servire js file da un controllore:
public ActionResult GetFileContent(string filename)
{
// important: make sure to control the path for security
var path = Server.MapPath("~/Scripts/" + filename);
var content = System.IO.File.ReadAllText(path);
// Use some kind of template convention
content = content.Replace("{{IMAGE_PATH}}", Url.Content(@"~/my/image.png"));
var bytes = new UTF8Encoding().GetBytes(content);
return new FileContentResult(bytes, "text/javascript");
}
Tnx! Questo ha risolto il mio problema. –