Assets Pipeline

22
Assets Pipeline, или как я перестал боятся Rails 3.1 и полюбил клиентскую оптимизацию Андрей Ситник [email protected] evilmartians.com

Transcript of Assets Pipeline

Page 1: Assets Pipeline

Assets Pipeline,или как я перестал боятся Rails 3.1 и полюбил клиентскую оптимизацию

Андрей Ситник[email protected]

Page 2: Assets Pipeline

Языки в Групоне

CoffeeScript 303 КБ

619 КБ

931 КБ

1021 КБ

Sass

Ruby

Haml

Page 3: Assets Pipeline

Хороший front-endSass

.icon { background: inline-image("icons/add.png"); @include border-radius(3px);} ↓.icon { background: url('…'); border-radius: 3px; -webkit-border-radius: 3px; -moz-border-radius: 3px;}

Page 4: Assets Pipeline

Хороший front-endОбъединить, сжать и закешировать

<script src="core.js"></script><script src="flash.js"></script><script src="home.js"></script>

<script src="app.js?1314096925"></script>

Page 5: Assets Pipeline

Сейчас — Rails 2.x…3.0

Jammitconfig/assets.ymljavascripts: app: - public/javascripts/core.js - public/javascripts/flash.js - public/javascripts/home.js

app/layouts/application.haml= include_javascripts :app

Barista

app/coffeescripts/core.coffee

public/javascripts/core.js

Page 6: Assets Pipeline

Проблемы

― Не учитываются зависимости

― Интеграция — сообщения об ошибках

― Сложно расширить функционал

― Cache buster file?timestamp иногда не работает

― Сторонние JS-библиотеки в репозитории

― Плагин не может подключить свои JS или CSS

― JS- и CSS-файлы не в app/

Page 7: Assets Pipeline

Assets PipelineЗависимости

В каждом файле указывается от каких файлов он зависит:

CoffeeScript:

#= require 'user'

SCSS

@import 'user';

Page 8: Assets Pipeline

Assets PipelineСообщения об ошибках

Page 9: Assets Pipeline

Assets PipelineФильтры

app/assets/javascripts/application.js.erb.coffee

Сначала откомпилить CoffeeScript в JS, а потом ERB

Можно добавить свои фильтры:

Rails.application.assets.register_postprocessor( 'application/javascript', Sprockets::SafetyColons)

Page 10: Assets Pipeline

Assets PipelineCache buster

application-25b93845b866436a84154200dd8d05e0.js ↑хеш от содержимоговместо времени изменения

Page 11: Assets Pipeline

Assets PipelineСторонние JS и CSS файлы

JS и CSS ищется в

app/assets/ файлы проекта

lib/assets/ свои библиотеки

vendor/assets/ сторонние библиотеки

А так же во всех gem’ах с Rails Engine

Page 12: Assets Pipeline

Как работает Assets PipelineШаг 1. Генерация

Собираем логику всех страниц в этом файлеapp/assets/javascripts/application.js.coffee

Логика страницы пользователей:app/assets/javascripts/user.js.coffee

Собираем стили всех страниц в этом файлеapp/assets/stylesheets/application.css.scss

Стили страницы пользователей:app/assets/stylesheets/user.css.scss

Page 13: Assets Pipeline

Как работает Assets PipelineШаг 2. Подключаем

app/views/layout/application.html.haml

= stylesheet_link_tag :application= javascript_include_tag :application

Page 14: Assets Pipeline

Как работает Assets PipelineШаг 3. Объединение

app/assets/javascrips/application.js.coffee

#= require 'user'#= require_tree 'pages'

app/assets/stylesheets/application.css.scss

@import 'user'

Page 15: Assets Pipeline

Как работает Assets PipelineШаг 4. Библиотеки

Gemfile

gem "jquery-rails"

app/assets/javascripts/application.js.coffee

#= require jquery

Page 16: Assets Pipeline

Как работает Assets PipelineШаг 5. Изображения

Путь к изображениям: app/assets/images

В SCSS и SASS все картинки надо указывать черезimage-url() вместо url()

.icon { background: image-url("user/icon.png"); }

В Haml использовать всегдаimage_tag("user/icon.png") илиimage_path("user/icon.png")

Page 17: Assets Pipeline

Как работает Assets PipelineШаг 6. Фильтры

1. Preprocessor — Смотрим какие файлы от каких зависят

2. Engine — Компилируем (CoffeeScript JS, SCSS CSS)→ →

3. Postprocessor — Исправляем файлы. Например, вставляем ; в JS-файлы

4. Собираем файлы в один

5. Bundle processors — Исправляем файлы-пакеты.Например, убираем повторы @charset в CSS-файлах

6. Compressor — Убираем лишние символы в JS и CSS.

7. Записываем файлы и сжимает в Gzip,чтобы веб-серверу было проще

Page 18: Assets Pipeline

Как работает Assets PipelineШаг 7. Отладка

В development файлы идут отдельно:

<script src='/assets/application.js?body=1'></script><script src='/assets/user.js?body=1'></script><script src='/assets/page/home.js?body=1'></script>

Чтобы выключить объединение в production,надо добавить ?debug_assets=1 в URL и разрешитьотладку в настройках:config.assets.allow_debugging = true

Page 19: Assets Pipeline

Как работает Assets PipelineШаг 8. Выкладка

Заранее собираются только application.css и applications.js.Остальные пакеты нужно добавить в настройках:

config.assets.precompile += %w( admin.js admin.css )

Перед деплоем нужно выполнить:rake assets:precompile

Для Capistrano 2.8 есть готовые рецепты:load 'deploy/assets'

Page 20: Assets Pipeline

Как работает Assets PipelineШаг 9. Кеширование

Говорим браузеру кешировать файлы ине спрашивать нас больше о них:

location ~ ^/(assets)/ { root /path/to/public; gzip_static on; expires max; add_header Cache-Control public;}

Page 21: Assets Pipeline

Как выложить своюJS-библиотеку

1. Стили и JS разместить в vendor/assets/

2. В lib/имя_гема.rb сделать класс,наследующий ::Rails::Engine

3. Написать имя_гема.gemspec, собрать gemи выложить на rubygems.org

Page 22: Assets Pipeline

Вопросы?

[email protected]