Angularjs, код углового материала загружается каждый раз [dубликат]

Просто используйте параметр SORT_REGULAR в качестве второго параметра.

  $ uniqueArray = array_unique ($ array, SORT_REGULAR);   
49
задан Ken 22 November 2008 в 09:19
поделиться

7 ответов

Посмотрите на Yahoo! советы: https://developer.yahoo.com/performance/rules.html#expires.

Есть также советы от Google: https://developer.yahoo.com/performance/rules.html#expires

22
ответ дан powtac 16 August 2018 в 05:18
поделиться

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

будет ли скрипт в теге скрипта html с расширением php кэшироваться? Когда браузер автоматически очищает кеш внешнего файла JavaScript? Помощь с агрессивным кешированием JavaScript Как контролировать кеширование веб-страниц во всех браузерах? Как заставить браузер видеть изменения CSS и Javascript?
7
ответ дан Community 16 August 2018 в 05:18
поделиться
  • 1
    Кажется, хороший кандидат на общий вопрос сообщества? Это, очевидно, зуд, который многие люди должны поцарапать. – Ken 22 November 2008 в 09:35

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

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

Если вы поклонник Улучшение производительности и hellip; (или nginx на простом английском языке), как и я, вы также можете легко настроить его:

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

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

Теперь, когда вы знаете правильные слова для поиска (заголовки HTTP «Expires», «Last-Modified» и «Cache-Control»), просто просмотрите документацию используемого веб-сервера.

0
ответ дан Eugene Lazutkin 16 August 2018 в 05:18
поделиться

У меня простая система, которая является чистым 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» на ваш файл, который всегда запускается, и «версия» с имя, которое вы хотите использовать для локального хранилища.

0
ответ дан joel Moses 16 August 2018 в 05:18
поделиться

В вашем файле 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- ваш сайт-с-HTTP-кэширование /

4
ответ дан Kalid 16 August 2018 в 05:18
поделиться

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

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

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

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

Полная библиотека: [ ! d12] 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'); });
7
ответ дан select 16 August 2018 в 05:18
поделиться

или в файле .htaccess

AddOutputFilter DEFLATE css js ExpiresActive On ExpiresByType application/x-javascript A2592000
23
ответ дан William Macdonald 16 August 2018 в 05:18
поделиться
  • 1
    ^ В вопросе не упоминается Apache, поэтому ... что-то действительно, C также было бы действительным. – Carlos Pliego 1 October 2015 в 21:15
  • 2
    [D0] Источник / Описание – lucidbrot 7 August 2018 в 17:50
Другие вопросы по тегам:

Похожие вопросы: