8

我正在使用 jqgrid 开发一个 ASPNET MVC 4 项目。

在那里,ASPNET MVC 4 默认放置

@Scripts.Render("~/bundles/jquery")

在 _Layout.cshtml 文件的末尾。

现在,我有一个使用 jqgrid 的 Index.cshtml

<script type="text/javascript">
    jQuery("#ajaxGrid").jqGrid({

所以我必须包括 jqgrid 脚本,如

@section jqgridScripts
{
    <script src="@Url.Content("~/Scripts/jqgrid/i18n/grid.locale-en.js")" type="text/javascript"></script>
    <script src="@Url.Content("~/Scripts/jqgrid/js/jquery.jqGrid.min.js")" type="text/javascript"></script>
}

但是在使用 .jqgrid 之前,我需要加载 jqgrid 脚本,而这又需要加载 jquery 脚本,因此,jquery 脚本需要位于 _Layout.cshtml 文件的顶部而不是末尾。

根据最佳实践 jquery 脚本需要在文件末尾加载,但如果我这样做,在 Index.cshtml 文件中它不知道 jQuery 是什么。

我不能将 jqquery 脚本和下面的 jqgrid 脚本放在 _Layout.cshtml 文件的底部,因为上面是使用 jqgrid 脚本的 Index.cshtml 文件内容。

为了能够将jQuery放在最后并且仍然能够在视图中使用jquery,我是否缺少一些东西?

谢谢!吉列尔莫。

4

2 回答 2

15

__Layout.cshtml:

@Scripts.Render("~/bundles/jquery")
@RenderSection("jqgridScripts", required: false);

@* for script in current page *@
@RenderSection("pageScripts", required: false);

索引.cshtml:

@section pageScripts
{
<script type="text/javascript">
    jQuery("#ajaxGrid").jqGrid({
    ... 
</script>
}

但最好的做法是为您的代码创建一个单独的 javascript 文件,如下所示:

__Layout.cshtml:

@Scripts.Render("~/bundles/jquery")
@RenderSection("pageScripts", required: false);

索引.cshtml:

@section pageScripts
{
    <script src="@Url.Content("~/Scripts/jqgrid/i18n/grid.locale-en.js")" type="text/javascript"></script>
    <script src="@Url.Content("~/Scripts/jqgrid/js/jquery.jqGrid.min.js")" type="text/javascript"></script>
    <script src="@Url.Content("~/Scripts/Site/myscript.js")" type="text/javascript"></script>
}

myscript.js:

$(function() {

   jQuery("#ajaxGrid").jqGrid({ ... });

});
于 2012-11-27T15:10:27.310 回答
2

我也遇到过这个问题。不捆绑 jQuery 本身似乎有点违反直觉,但这是必须要做的。在标题中向上抛出一个 jQuery 脚本引用。如果您将 jQuery 脚本 src 属性设置为缩小的 google 托管实例的属性,那么脚本很可能已经缓存在您的客户端中。

这是一个很好的参考...

于 2012-11-27T13:59:14.887 回答