How can I force clients to refresh JavaScript files?

后端 未结 26 2270
旧时难觅i
旧时难觅i 2020-11-22 03:40

We are currently working in a private beta and so are still in the process of making fairly rapid changes, although obviously as usage is starting to ramp up, we will be slo

相关标签:
26条回答
  • As far as I know a common solution is to add a ?<version> to the script's src link.

    For instance:

    <script type="text/javascript" src="myfile.js?1500"></script>
    

    I assume at this point that there isn't a better way than find-replace to increment these "version numbers" in all of the script tags?

    You might have a version control system do that for you? Most version control systems have a way to automatically inject the revision number on check-in for instance.

    It would look something like this:

    <script type="text/javascript" src="myfile.js?$$REVISION$$"></script>
    

    Of course, there are always better solutions like this one.

    0 讨论(0)
  • 2020-11-22 04:22

    In PHP:

    function latest_version($file_name){
        echo $file_name."?".filemtime($_SERVER['DOCUMENT_ROOT'] .$file_name);
    }
    

    In HTML:

    <script type="text/javascript" src="<?php latest_version('/a-o/javascript/almanacka.js'); ?>">< /script>
    

    How it works:

    In HTML, write the filepath and name as you wold do, but in the function only. PHP gets the filetime of the file and returns the filepath+name+"?"+time of latest change

    0 讨论(0)
  • 2020-11-22 04:22

    Cache Busting in ASP.NET Core via a tag helper will handle this for you and allow your browser to keep cached scripts/css until the file changes. Simply add the tag helper asp-append-version="true" to your script (js) or link (css) tag:

    <link rel="stylesheet" href="~/css/site.min.css" asp-append-version="true"/>
    

    Dave Paquette has a good example and explanation of cache busting here (bottom of page) Cache Busting

    0 讨论(0)
  • 2020-11-22 04:23

    How about adding the filesize as a load parameter?

    <script type='text/javascript' src='path/to/file/mylibrary.js?filever=<?=filesize('path/to/file/mylibrary.js')?>'></script>
    

    So every time you update the file the "filever" parameter changes.

    How about when you update the file and your update results in the same file size? what are the odds?

    0 讨论(0)
  • 2020-11-22 04:23

    If you're generating the page that links to the JS files a simple solution is appending the file's last modification timestamp to the generated links.

    This is very similar to Huppie's answer, but works in version control systems without keyword substitution. It's also better than append the current time, since that would prevent caching even when the file didn't change at all.

    0 讨论(0)
  • 2020-11-22 04:23

    FRONT-END OPTION

    I made this code specifically for those who can't change any settings on the backend. In this case the best way to prevent a very long cache is with:

    new Date().getTime()
    

    However, for most programmers the cache can be a few minutes or hours so the simple code above ends up forcing all users to download "the each page browsed". To specify how long this item will remain without reloading I made this code and left several examples below:

    // cache-expires-after.js v1
    function cacheExpiresAfter(delay = 1, prefix = '', suffix = '') { // seconds
        let now = new Date().getTime().toString();
        now = now.substring(now.length - 11, 10); // remove decades and milliseconds
        now = parseInt(now / delay).toString();
        return prefix + now + suffix;
    };
    
    // examples (of the delay argument):
    // the value changes every 1 second
    var cache = cacheExpiresAfter(1);
    // see the sync
    setInterval(function(){
        console.log(cacheExpiresAfter(1), new Date().getSeconds() + 's');
    }, 1000);
    
    // the value changes every 1 minute
    var cache = cacheExpiresAfter(60);
    // see the sync
    setInterval(function(){
        console.log(cacheExpiresAfter(60), new Date().getMinutes() + 'm:' + new Date().getSeconds() + 's');
    }, 1000);
    
    // the value changes every 5 minutes
    var cache = cacheExpiresAfter(60 * 5); // OR 300
    
    // the value changes every 1 hour
    var cache = cacheExpiresAfter(60 * 60); // OR 3600
    
    // the value changes every 3 hours
    var cache = cacheExpiresAfter(60 * 60 * 3); // OR 10800
    
    // the value changes every 1 day
    var cache = cacheExpiresAfter(60 * 60 * 24); // OR 86400
    
    // usage example:
    let head = (document.head || document.getElementsByTagName('head')[0]);
    let script = document.createElement('script');
    script.setAttribute('src', '//unpkg.com/sweetalert@2.1.2/dist/sweetalert.min.js' + cacheExpiresAfter(60 * 5, '?'));
    head.append(script);
    
    // this works?
    let waitSwal = setInterval(function() {
        if (window.swal) {
            clearInterval(waitSwal);
            swal('Script successfully injected', script.outerHTML);
        };
    }, 100);
    
    0 讨论(0)
提交回复
热议问题