Giter Site home page Giter Site logo

webperformancechecklist's Introduction

Чек-лист оптимизации скорости загрузки сайта

Инструменты анализа скорости загрузки сайта с выдачей рекомендаций:

GTmetrix использует Google Page Speed + Yahoo! YSlow и выдает подробные рекомендации, зато Google PageSpeed Insights проверяет также загрузку на мобильных устройствах.

Серверное

  1. Включение HTTP2
  2. Включение gzip
  3. Включение кеширования генерации страниц движком сайта
  4. Включение кеширования для файлов, отдаваемых сервером:
  5. Last-Modifed
  6. Expires headers
  7. E-tag
  8. Cache-Control
  9. Vary: Accept-Encoding header
  10. Проверка чтоб не было 404-тых откликов на загрузку ресурсов - они замедляют загрузку

##Верстка 5. Подключение CSS и JS - в конце HTML, перед </body> 6. Автоматически генерировать критический CSS и вставлять его через <style> в <head> 6. Минимизировать кол-во загружаемых файлов (не очень актуально, если есть HTTP2):

  1. Использовать CSS-спрайты
  2. Использовать base64 или инлайнить svg для небольших изображений
  3. Объединять все css в один файл
  4. Объединять все js в один файл
  5. Использовать только WOFF2 и WOFF при подключении web fonts. Подробнее про подключение.
  6. Отложить загрузку данных необязательных для первого отображения страницы:
  7. Использовать defer и async для стороннего js
  8. Вынести кнопки соц. шаринга в пост-загрузку или загружать их при прокрутке содержимого к ним
  9. Использовать LazyLoad для картинок, но не в ущерб SEO (scr ведет на основную картинку).
  10. Подгружать невидимые при первой загрузке части страницы через AJAX (например содержимое табов) или через prerender, подробнее
  11. Подгружать через prerender блоки неиспользуемые на текущей странице, но будут нужны для следующих
  12. Подгружать js-библиотеки и шрифты с CDN - для использования их версий закешированных с других сайтов и быстрой загрузки с CDN если кеша нет
  13. Перенести внешние баннеры и другие ресурсы подгружаемые со сторонних медленных серверов - на сервер клиента
  14. Минимизировать редиректы для внешних ресурсов (например внешний js отдается не по тому URL, по которому запрашивается, а по редиректу стого URL)
  15. Прописать размеры img в html
  16. Минимизировать CSS, JS и HTML
  17. Оптимизировать графику:
  18. Не грузить на обычный дисплей ретина изображения. Использовать retinajs и миксины.
  19. Либо использовать технику 30% quality Retina JPG
  20. Конвертация типа картинок: - svg (предпочтительней) или png - для векторных изображений, диаграмм, строгих переходов цветов - jpg - для полноцвета и градиентов - png24 для прозрачностей - png8 с альфа-каналом для прозрачностей (через оптимизатор графики http://compresspng.com/) Возможно где-то можно заменить png24 на png8+matte, а где-то на jpg
  21. Сохранять JPG как progressive
  22. Оптимизировать jpg и png-файлы: - с помощью http://compresspng.com/ и http://compressjpeg.com/ (сжимают лучше и быстрей чем консольные утилиты) - или с помощь консольных утилит pngout, jpegtrank (в том числе плагинами к Grunt/Gulp)
  23. Перенос визуальных украшений в CSS3 вместо картинок: - например тень у картинки можно сделать через box-shadow, а саму картинку сохранить без тени
  24. Объединять несколько рядом стоящих картинок-ссылок в одну картинку, на которую накладываются позиционированные ссылки
  25. Внести правки в дизайн, удалив тяжеловесные элементы
  26. Желательно удалить query string ("?") в URL отдаваемых ресурсов (некоторые прокси не кешируют их)

webperformancechecklist's People

Contributors

ihorzenich avatar

Watchers

James Cloos avatar Vlad Trukhin avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.