require.js - How can I set a version on required modules as part of the URL?

后端 未结 4 1783
爱一瞬间的悲伤
爱一瞬间的悲伤 2021-01-21 06:50

I am using require.js to require JS modules in my application.

I need a way to bust client cache on new JS modules, by way of a different requested URL.

i.e., if

相关标签:
4条回答
  • 2021-01-21 07:08

    Just do it like the creator of requirejs suggests:

    var load = requirejs.load;
    requirejs.load = function (context, moduleId, url) {
      // modify url here
      url = url.substring(0, url.lastIndexOf('.')) + '.' + VERSION + url.substring(url.lastIndexOf('.'));
      return load(context, moduleId, url);
    };
    

    https://github.com/jrburke/requirejs/wiki/Fine-grained-URL-control

    0 讨论(0)
  • 2021-01-21 07:22

    I got really frustrated with the urlArgs solution and finally gave up and implemented my own fix directly into require.js. This fix implements your ideal solution, if you are willing to modify your version of the library.

    You can see the patch here:

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

    Once added, you can do something like this in your require config:

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

    Use your build system or server environment to replace buildNumber with a revision id or software version.

    Using require like this:

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

    Will cause require to request this file:

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

    The patch will ignore any script that specifies a protocol, and it will not affect any non-JS files.

    On our server environment, we use url rewrite rules to strip out the buildNumber, and serve the correct JS file. This way we don't actually have to worry about renaming all our JS files.

    This works well for my environment, but I realize some users would prefer a prefix rather than a suffix, it should be easy to modify my commit to suit your needs.

    Here are some possible duplicate questions:

    RequireJS and proxy caching

    Prevent RequireJS from Caching Required Scripts

    0 讨论(0)
  • 2021-01-21 07:22

    HTML5 Boilerplate has ant-build-script that renames your files and any reference to them for this exact reason and can do alot more. It's worth checking out if you haven't already.

    0 讨论(0)
  • 2021-01-21 07:24

    OK, I googled "requirejs cache bust" for you and found this existing SO answer, which says you can configure requireJS with an urlArgs parameter, which is only a partial solution, but it might be enough to meet your immediate needs.

    That said, the cachebusting problem is full of challenges and many "solutions" don't actually solve the problem in its entirety. The only maintainable way to do this (IMHO as of now) is with a full-on asset management system like the Ruby on Rails asset pipeline or connect-assets or the equivalent for your server side framework of choice. Those can correct compute a checksum (usually MD5 or SHA1) of the content of each file and give you the file names you need to put as URLs in your HTML script tags. So, don't bother with manually changing filenames based on version numbers, just use checksums since they are easily automated and foolproof.

    From what I can tell, out of the box requirejs can't do the cachebusting aspect for you. You might want to read this google groups thread. Otherwise, you may need to pair requirejs with an additional tool/script to get you good cachebuster checksums.

    0 讨论(0)
提交回复
热议问题