2014-09-03 4 views
2

Я пытаюсь сжать все файлы веб-сайта, чтобы оптимизировать производительность веб-сайта. До сих пор я включил секцию сжатия из примера HTML5 boilerplate .htaccess.Принудительное сжатие GZIP в файлах JavaScript

Вот соответствующий фрагмент кода:

# ------------------------------------------------------------------------------ 
# | Compression                | 
# ------------------------------------------------------------------------------ 

<IfModule mod_deflate.c> 

# Force compression for mangled headers. 
# http://developer.yahoo.com/blogs/ydn/posts/2010/12/pushing-beyond-gzipping 
<IfModule mod_setenvif.c> 
    <IfModule mod_headers.c> 
     SetEnvIfNoCase ^(Accept-EncodXng|X-cept-Encoding|X{15}|~{15}|-{15})$ ^((gzip|deflate)\s*,?\s*)+|[X~-]{4,13}$ HAVE_Accept-Encoding 
     RequestHeader append Accept-Encoding "gzip,deflate" env=HAVE_Accept-Encoding 
    </IfModule> 
</IfModule> 

# Compress all output labeled with one of the following MIME-types 
# (for Apache versions below 2.3.7, you don't need to enable `mod_filter` 
# and can remove the `<IfModule mod_filter.c>` and `</IfModule>` lines 
# as `AddOutputFilterByType` is still in the core directives). 
<IfModule mod_filter.c> 
    AddOutputFilterByType DEFLATE application/atom+xml \ 
            application/javascript \ 
            application/json \ 
            application/rss+xml \ 
            application/vnd.ms-fontobject \ 
            application/x-font-ttf \ 
            application/x-web-app-manifest+json \ 
            application/xhtml+xml \ 
            application/xml \ 
            font/opentype \ 
            image/svg+xml \ 
            image/x-icon \ 
            text/css \ 
            text/html \ 
            text/plain \ 
            text/x-component \ 
            text/xml 
</IfModule> 

</IfModule> 

После просмотра gzipwtf.com кажется сайт клиентов GZIPing все CSS файлы, но по какой-то причине JavaScript игнорируется. Я довольно новичок в радостях .htaccess и этой стороне вещей, поэтому я не уверен, как заставить форсировать сжатие. Какие-либо предложения?

+0

герой! Спасибо, это работает нормально. Если вы хотите записать его в качестве ответа, я дам вам престиж. Я также поднял проблему с репозиторией Boilerplate HTML5, чтобы убедиться, что она исправлена. Еще раз спасибо! – Sheixt

ответ

3

Для обеспечения правильной совместимости необходимо указать два типа пантомимы для JavaScript:

application/javascript 
text/javascript 

Там еще один, но AFAICT он использовался только в переходный период:

application/x-javascript