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)的特定解决方案,请参阅下面的一些答案。


当前回答

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

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

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

其他回答

urlArgs解决方案有问题。不幸的是,您无法控制可能在您和用户的web浏览器之间的所有代理服务器。不幸的是,其中一些代理服务器可能被配置为在缓存文件时忽略URL参数。如果发生这种情况,将会向用户发送错误的JS文件版本。

我最终放弃了,并直接在require.js中实现了自己的修复。如果您愿意修改requirejs库的版本,这个解决方案可能适合您。

你可以在这里看到补丁:

https://github.com/jbcpollak/requirejs/commit/589ee0cdfe6f719cd761eee631ce68eee09a5a67

一旦添加,你可以在require配置中做这样的事情:

var require = {
    baseUrl: "/scripts/",
    cacheSuffix: ".buildNumber"
}

使用构建系统或服务器环境将buildNumber替换为修订id /软件版本/喜欢的颜色。

像这样使用require:

require(["myModule"], function() {
    // no-op;
});

将导致需要请求此文件:

http://yourserver.com/scripts/myModule.buildNumber.js

在我们的服务器环境中,我们使用url重写规则来去除buildNumber,并提供正确的JS文件。这样我们就不必担心重命名所有的JS文件。

该补丁将忽略任何指定协议的脚本,也不会影响任何非js文件。

这在我的环境中工作得很好,但我意识到有些用户更喜欢前缀而不是后缀,因此应该很容易修改我的提交以满足您的需求。

更新:

在拉请求的讨论中,requirejs作者建议这可以作为一个解决方案,为修订号添加前缀:

var require = {
    baseUrl: "/scripts/buildNumber."
};

我没有尝试过这个,但其含义是,这将请求以下URL:

http://yourserver.com/scripts/buildNumber.myModule.js

这对于许多会使用前缀的人来说可能非常有用。

以下是一些可能重复的问题:

RequireJS和代理缓存

require.js -我如何设置所需模块的版本作为URL的一部分?

受到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@',
    ...
});

这是我在Django / Flask中如何做到的(可以很容易地适应其他语言/ VCS系统):

在config.py中(我在python3中使用这个,所以你可能需要调整python2中的编码)

import subprocess
GIT_HASH = subprocess.check_output(['git', 'rev-parse', 'HEAD']).strip().decode('utf-8')

然后在模板中:

{% if config.DEBUG %}
     require.config({urlArgs: "bust=" + (new Date().getTime())});
{% else %}
    require.config({urlArgs: "bust=" + {{ config.GIT_HASH|tojson }}});
{% endif %}

不需要手动构建过程 应用程序启动时只运行git rev-parse HEAD一次,并将其存储在配置对象中

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

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

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

我从AskApache中获取了这段代码,并将其放入本地Apache web服务器的一个单独的.conf文件中(在我的情况下是/etc/apache2/ others/preventcache .conf):

<FilesMatch "\.(html|htm|js|css)$">
FileETag None
<ifModule mod_headers.c>
Header unset ETag
Header set Cache-Control "max-age=0, no-cache, no-store, must-revalidate"
Header set Pragma "no-cache"
Header set Expires "Wed, 11 Jan 1984 05:00:00 GMT"
</ifModule>
</FilesMatch>

对于开发来说,这很好,不需要更改代码。至于制作,我可能会使用@dvtoever的方法。