Кеширование файлов JavaScript

Какой лучший способ заставить браузер использовать кешированные версии файлов js (со стороны сервера)?

Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
52
0
149 092
8
Перейти к ответу Данный вопрос помечен как решенный

Ответы 8

Из PHP:

function OutputJs($Content) 
{   
    ob_start();
    echo $Content;
    $expires = DAY_IN_S; // 60 * 60 * 24 ... defined elsewhere
    header("Content-type: x-javascript");
    header('Content-Length: ' . ob_get_length());
    header('Cache-Control: max-age='.$expires.', must-revalidate');
    header('Pragma: public');
    header('Expires: '. gmdate('D, d M Y H:i:s', time()+$expires).'GMT');
    ob_end_flush();
    return; 
}   

работает для меня.

Как разработчик вы, вероятно, быстро столкнетесь с ситуацией, когда вам не нужно, чтобы файлы были кэшированы, и в этом случае см. Помощь с агрессивным кешированием JavaScript

или в файле .htaccess

AddOutputFilter DEFLATE css js
ExpiresActive On
ExpiresByType application/x-javascript A2592000

^ В вопросе не упоминается Apache, поэтому ... все верно, C также был бы допустим.

Carlos Pliego 02.10.2015 00:15
Источник / Пояснение
lucidbrot 07.08.2018 20:50

Я испытываю сильное искушение закрыть это как дубликат; на этот вопрос, кажется, можно ответить по-разному на всем сайте:

Значит, кажется хорошим кандидатом на общий вопрос сообщества? Очевидно, что это зуд, который нужно чесать многим.

Ken 22.11.2008 11:35

В вашем файле Apache .htaccess:

#Create filter to match files you want to cache 
<Files *.js>
Header add "Cache-Control" "max-age=604800"
</Files>

Я также писал об этом здесь:

http://betterexplained.com/articles/how-to-optimize-your-site-with-http-caching/

Ответ принят как подходящий

Взгляните на Yahoo! советы: https://developer.yahoo.com/performance/rules.html#expires.

Также есть подсказки от Google: https://developers.google.com/speed/docs/insights/LeverageBrowserCaching

Лучший (и единственный) метод - установить правильные заголовки HTTP, в частности эти: «Истекает», «Последнее изменение» и «Cache-Control». Как это сделать, зависит от серверного программного обеспечения, которое вы используете.

В Повышение производительности… найдите «Оптимизация на стороне сервера», чтобы получить общие сведения и соответствующие ссылки, а также «Кэш на стороне клиента», чтобы получить рекомендации, относящиеся к Apache.

Если вы, как и я, являетесь поклонником nginx (или nginx на простом английском), вы также можете легко настроить его:

location /images {
  ...
  expires 4h;
}

В приведенном выше примере любой файл из / images / будет кэшироваться на клиенте в течение 4 часов.

Теперь, когда вы знаете нужные слова для поиска (заголовки HTTP «Истекает», «Последнее изменение» и «Управление кешем»), просто просмотрите документацию по используемому вами веб-серверу.

Я только что закончил свой проект выходного дня cached-webpgr.js который использует localStorage / веб-хранилище для кеширования файлов JavaScript. Этот подход очень быстрый. Мой небольшой тест показал

  • Загрузка jQuery из CDN: Chrome 268 мс, FireFox: 200 мс
  • Загрузка jQuery из localStorage: Chrome 47 мс, FireFox 14 мс

Код для этого крошечный, вы можете проверить его в моем проекте Github https://github.com/webpgr/cached-webpgr.js.

Вот полный пример того, как его использовать.

Полная библиотека:

function _cacheScript(c,d,e){var a=new XMLHttpRequest;a.onreadystatechange=function(){4==a.readyState&&(200==a.status?localStorage.setItem(c,JSON.stringify({content:a.responseText,version:d})):console.warn("error loading "+e))};a.open("GET",e,!0);a.send()}function _loadScript(c,d,e,a){var b=document.createElement("script");b.readyState?b.onreadystatechange=function(){if ("loaded"==b.readyState||"complete"==b.readyState)b.onreadystatechange=null,_cacheScript(d,e,c),a&&a()}:b.onload=function(){_cacheScript(d,e,c);a&&a()};b.setAttribute("src",c);document.getElementsByTagName("head")[0].appendChild(b)}function _injectScript(c,d,e,a){var b=document.createElement("script");b.type = "text/javascript";c=JSON.parse(c);var f=document.createTextNode(c.content);b.appendChild(f);document.getElementsByTagName("head")[0].appendChild(b);c.version!=e&&localStorage.removeItem(d);a&&a()}function requireScript(c,d,e,a){var b=localStorage.getItem(c);null==b?_loadScript(e,c,d,a):_injectScript(b,c,d,a)};

Звонок в библиотеку

requireScript('jquery', '1.11.2', 'http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js', function(){
    requireScript('examplejs', '0.0.3', 'example.js');
});

У меня простая система - чистый JavaScript. Он проверяет наличие изменений в простом текстовом файле, который никогда не кэшируется. Когда вы загружаете новую версию, этот файл изменяется. Просто поместите следующий JS вверху страницы.

        (function(url, storageName) {
            var fromStorage = localStorage.getItem(storageName);
            var fullUrl = url + "?rand = " + (Math.floor(Math.random() * 100000000));
            getUrl(function(fromUrl) {
//                   first load
                if (!fromStorage) {
                    localStorage.setItem(storageName, fromUrl);
                    return;
                }
//                    old file
                if (fromStorage === fromUrl) {
                    return;
                }
                // files updated
                localStorage.setItem(storageName, fromUrl);
                location.reload(true);
            });
            function getUrl(fn) {
                var xmlhttp = new XMLHttpRequest();
                xmlhttp.open("GET", fullUrl, true);
                xmlhttp.send();
                xmlhttp.onreadystatechange = function() {
                    if (xmlhttp.readyState === XMLHttpRequest.DONE) {
                        if (xmlhttp.status === 200 || xmlhttp.status === 2) {
                            fn(xmlhttp.responseText);
                        }
                        else if (xmlhttp.status === 400) {
                            throw 'unable to load file for cache check ' +  url;
                        }
                        else {
                           throw 'unable to load file for cache check ' +  url;
                        }
                    }
                };
            }
            ;
        })("version.txt", "version");

просто замените «version.txt» на ваш файл, который всегда запускается, а «version» на имя, которое вы хотите использовать для своего локального хранилища.

Другие вопросы по теме