2017-05-24 11 views
0

私のASP MVCアプリケーションで次のバンドルを設定しました。バンドルのレンダリング順序が含まれていない

bundles.Add(new ScriptBundle("~/Scripts/Core").Include(
       "~/Content/th/assets/global/plugins/jquery.min.js", // Should be first 
       "~/Content/th/assets/global/plugins/bootstrap/js/bootstrap.min.js", 
       "~/Content/th/assets/global/plugins/js.cookie.min.js", 
       "~/Content/th/assets/global/plugins/jquery-slimscroll/jquery.slimscroll.min.js", 
       "~/Content/th/assets/global/plugins/jquery.blockui.min.js", 
       "~/Content/th/assets/global/plugins/jquery-ui/jquery-ui.min.js", // Should be after jquery.min.js 
       "~/Content/th/assets/global/plugins/bootstrap-switch/js/bootstrap-switch.min.js", 
       "~/Content/th/assets/global/plugins/bootstrap-select/js/bootstrap-select.min.js", 
       "~/Content/th/assets/pages/scripts/components-bootstrap-select.js", 
       "~/Content/th/assets/pages/scripts/portlet-draggable.min.js", 
       "~/Content/th/assets/global/plugins/bootstrap-multiselect/js/bootstrap-multiselect.js", 
       "~/Content/th/assets/global/plugins/po/jquery.webui-popover.min.js", 
       "~/Content/th/assets/pages/scripts/components-bootstrap-multiselect.min.js", 
       "~/Content/th/assets/pages/scripts/components-date-time-pickers.js" 

なぜjquery-ui.min.jsが最初に出力されるのですか?どうすればjavascriptエラーを生成するので、この動作を防ぐことができますか?あなたは1

internal class AsIsBundleOrderer : IBundleOrderer 
{ 
    public virtual IEnumerable<FileInfo> OrderFiles(BundleContext context, IEnumerable<FileInfo> files) 
    { 
     return files; 
    } 
} 

internal static class BundleExtensions 
{ 
    public static Bundle ForceOrdered(this Bundle sb) 
    { 
     sb.Orderer = new AsIsBundleOrderer(); 
     return sb; 
    } 
} 

の下に使用することができ、予想通りここ

は秩序を維持するために、MVC5バージョンの @Scripts.Render("~/Scripts/Core")

<script src="/Content/th/assets/global/plugins/jquery-ui/jquery-ui.min.js"></script> 
<script src="/Content/th/assets/global/plugins/jquery.min.js"></script> 
<script src="/Content/th/assets/global/plugins/bootstrap/js/bootstrap.min.js"></script> 
<script src="/Content/th/assets/global/plugins/js.cookie.min.js"></script> 
<script src="/Content/th/assets/global/plugins/jquery-slimscroll/jquery.slimscroll.min.js"></script> 
<script src="/Content/th/assets/global/plugins/jquery.blockui.min.js"></script> 
<script src="/Content/th/assets/global/plugins/bootstrap-switch/js/bootstrap-switch.min.js"></script> 
<script src="/Content/th/assets/global/plugins/bootstrap-select/js/bootstrap-select.min.js"></script> 
<script src="/Content/th/assets/pages/scripts/components-bootstrap-select.js"></script> 
<script src="/Content/th/assets/pages/scripts/portlet-draggable.min.js"></script> 
<script src="/Content/th/assets/global/plugins/bootstrap-multiselect/js/bootstrap-multiselect.js"></script> 
<script src="/Content/th/assets/global/plugins/po/jquery.webui-popover.min.js"></script> 
<script src="/Content/th/assets/pages/scripts/components-bootstrap-multiselect.min.js"></script> 
<script src="/Content/th/assets/pages/scripts/components-date-time-pickers.js"></script> 

答えて

3

から出力された線であり、そして、あなたは.ForceOrdered()メソッドへの言及バンドルしながら、指定した順序で表示されます。

bundles.Add(new ScriptBundle("~/Scripts/Core").Include(
       "~/Content/th/assets/global/plugins/jquery.min.js", // Should be first 
       "~/Content/th/assets/global/plugins/bootstrap/js/bootstrap.min.js", 
       "~/Content/th/assets/global/plugins/js.cookie.min.js", 
       "~/Content/th/assets/global/plugins/jquery-slimscroll/jquery.slimscroll.min.js", 
       "~/Content/th/assets/global/plugins/jquery.blockui.min.js", 
       "~/Content/th/assets/global/plugins/jquery-ui/jquery-ui.min.js", // Should be after jquery.min.js 
       "~/Content/th/assets/global/plugins/bootstrap-switch/js/bootstrap-switch.min.js", 
       "~/Content/th/assets/global/plugins/bootstrap-select/js/bootstrap-select.min.js", 
       "~/Content/th/assets/pages/scripts/components-bootstrap-select.js", 
       "~/Content/th/assets/pages/scripts/portlet-draggable.min.js", 
       "~/Content/th/assets/global/plugins/bootstrap-multiselect/js/bootstrap-multiselect.js", 
       "~/Content/th/assets/global/plugins/po/jquery.webui-popover.min.js", 
       "~/Content/th/assets/pages/scripts/components-bootstrap-multiselect.min.js", 
       "~/Content/th/assets/pages/scripts/components-date-time-pickers.js") 
.ForceOrdered()); 
関連する問題