问题:
在 ASP.NET MVC 4.5 中完成的 HTML5 离线应用程序中,我们使用框架的内置功能捆绑和缩小样式和脚本。页面本身的一切都运行良好,但要写入缓存清单,其中(因为我们正在编写它)它总是只发出捆绑的 URL。
因此,我们无法在离线模式下调试 JavaScript,因为单个调试 js 文件没有进入应用程序缓存。
代码:
注册包
这是我们的BundleConfig.RegisterBundles
外观:
// For more information on Bundling, visit http://go.microsoft.com/fwlink/?LinkId=254725
public static void RegisterBundles(BundleCollection bundles)
{
bundles.Add(new ScriptBundle("~/bundles/Scripts").Include(
"~/Scripts/*.js"
));
}
HTML 标记
我们将它包含在我们_Layout.cshtml
的页面本身中,如下所示:
@System.Web.Optimization.Scripts.Render("~/bundles/Scripts")
这适用于页面,通过在 is 时发出单个 js 文件,在debug
is时发出true
一个捆绑文件。debug
false
输出输入debug=true
<script src="/Scripts/ScriptOne.js"></script>
<script src="/Scripts/ScriptTwo.js"></script>
<script src="/Scripts/ScriptThree.js"></script>
输出输入debug=false
<script src="/bundles/Scripts?v=B0_RvAM_5ifnREcGnNQ3FO8qQp4vyLOdtCUJ-2mXSuA1"></script>
缓存清单
这就是我们如何将脚本包含到我们的CacheManifest
@System.Web.Optimization.BundleTable.Bundles.ResolveBundleUrl("~/bundles/Scripts")
输出debug=true
和debug=false
/bundles/Scripts?v=B0_RvAM_5ifnREcGnNQ3FO8qQp4vyLOdtCUJ-2mXSuA1
我们想要什么?
我们想知道是否有办法让 Cache-Manifest 像这样输出:
输出输入debug=true
/Scripts/ScriptOne.js
/Scripts/ScriptTwo.js
/Scripts/ScriptThree.js
输出输入debug=false
/bundles/Scripts?v=B0_RvAM_5ifnREcGnNQ3FO8qQp4vyLOdtCUJ-2mXSuA1