RequireJS似乎在内部做了一些事情,缓存所需的javascript文件。如果我对所需的文件之一进行了更改,我必须重命名该文件,以便应用更改。

将版本号作为查询字符串参数附加到文件名末尾的常见技巧不适用于requirejs <script src="jsfile.js? "脚本v2”> < / >

我正在寻找的是一种方法,以防止RequireJS所需脚本的这种内部缓存,而不必在每次更新脚本文件时重命名脚本文件。

跨平台解决方案:

我现在使用urlArgs: "bust=" + (new Date()). gettime()在开发过程中自动缓存破坏和urlArgs: "bust=v2"的生产,在推出一个更新的所需脚本后,我增加硬编码的版本num。

注意:

@Dustin Getz在最近的回答中提到,当Javascript文件不断刷新时,Chrome开发工具将在调试过程中删除断点。一个解决方法是编写调试器;在大多数Javascript调试器中触发断点。

特定于服务器的解决方案:

有关可能更适合您的服务器环境(如Node或Apache)的特定解决方案,请参阅下面的一些答案。


当前回答

这是对@phil mccull接受的回答的补充。

我使用了他的方法,但我也通过创建一个T4模板来自动运行预构建过程。

预构建命令:

set textTemplatingPath="%CommonProgramFiles(x86)%\Microsoft Shared\TextTemplating\$(VisualStudioVersion)\texttransform.exe"
if %textTemplatingPath%=="\Microsoft Shared\TextTemplating\$(VisualStudioVersion)\texttransform.exe" set textTemplatingPath="%CommonProgramFiles%\Microsoft Shared\TextTemplating\$(VisualStudioVersion)\texttransform.exe"
%textTemplatingPath% "$(ProjectDir)CacheBuster.tt"

T4模板:

生成的文件:

在require.config.js加载之前存储在变量中:

require.config.js中的引用:

其他回答

RequireJS可以配置为每个脚本url附加一个值,用于缓存破坏。

来自RequireJS文档(http://requirejs.org/docs/api.html#config):

urlArgs:额外的查询字符串参数附加到RequireJS的url 用于获取资源。最有用的缓存崩溃时,浏览器或 服务器配置不正确。

示例:将"v2"附加到所有脚本:

require.config({
    urlArgs: "bust=v2"
});

出于开发目的,你可以通过添加时间戳来强制RequireJS绕过缓存:

require.config({
    urlArgs: "bust=" + (new Date()).getTime()
});

受到require.js data-main上的过期缓存的启发,我们用以下ant任务更新了我们的部署脚本:

<target name="deployWebsite">
    <untar src="${temp.dir}/website.tar.gz" dest="${website.dir}" compression="gzip" />       
    <!-- fetch latest buildNumber from build agent -->
    <replace file="${website.dir}/js/main.js" token="@Revision@" value="${buildNumber}" />
</target>

main.js的开头是这样的:

require.config({
    baseUrl: '/js',
    urlArgs: 'bust=@Revision@',
    ...
});

在我的情况下,我想每次点击都加载相同的表单,我不希望我对文件所做的更改保持不变。它可能与这篇文章不太相关,但这可能是一个潜在的解决方案,在客户端不需要为require设置配置。无需直接发送内容,您可以复制所需文件并保持实际文件完整。

LoadFile(filePath){
    const file = require(filePath);
    const result = angular.copy(file);
    return result;
}

在生产中

urlArgs会导致问题!

requirejs的主要作者不喜欢使用urlArgs:

对于已部署的资产,我更喜欢将版本或哈希放在整体中 build作为构建目录,然后只需修改使用的baseUrl配置 项目使用该版本目录作为baseUrl。然后 没有其他文件更改,并且它有助于避免一些代理问题 不能缓存带有查询字符串的URL。

(样式我的。)

我遵循这个建议。

在开发中

我更喜欢使用智能缓存可能频繁更改的文件的服务器:发出Last-Modified并在适当的时候用304响应If-Modified-Since的服务器。即使是基于Node的快速集来提供静态文件的服务器也会立即这样做。它不需要对浏览器做任何操作,也不会弄乱断点。

我不建议使用'urlArgs'来处理RequireJS的缓存爆破。因为这并不能完全解决问题。更新版本no将导致下载所有资源,即使您只更改了单个资源。

为了解决这个问题,我建议使用Grunt模块,如“filerev”来创建修订号。在此之上,我已经在Gruntfile中编写了一个自定义任务,以在任何需要的地方更新修订。

如果需要,我可以分享这个任务的代码片段。