我是ASP.NET / MVC3的新手,我正在试图弄清楚如何将我的
JavaScript(包含C#)与HTML的其余部分分开.
如果我将它们放入.JS文件并使用脚本标记插入它们,那么它们的C#方面就会停止工作.在MVC 3 razor中分离包含C#代码的JavaScript代码的最佳方法是什么?
谢谢.
解决方法
出于多种原因,您最好将大部分(如果不是全部)JS放入单独的JS文件中(这样您就可以利用重用,缩小,浏览器优化,内容交付网络等)
要将服务器端razor代码的结果读入JS文件,请使用以下方法之一:
1)将您的剃刀代码放入视图中的javascript变量(未测试代码)
<script type="text/javascript"> if(!MyGlobalVariables){ MyGlobalVariables = {}; } MyGlobalVariables.IndexUrl = "@Url.Action("Index")"; </script>
2)使用自定义属性(最好以数据为前缀 – 如HTML 5 spec中所建议).请参阅此处的相关讨论:Can I add custom attribute to HTML tag?
<div data-index-url="@Url.Action("Index")"></div>
然后,在jQuery中使用$(this).attr(“data-index-url”)来访问渲染的剃刀标记.
3)将C#放入视图中的隐藏输入字段,并读取JS文件中的隐藏输入.
<input id="indexUrl" type="hidden" value="@Url.Action("Index")" />
要在jQuery中读取它,您将使用$(“#indexUrl”).val()