Frontend опыт Travelpayouts: как сделать идеальный виджет

Россия+7 (495) 960-65-87
Шрифт:
0 1110

Мы постоянно работаем над улучшением наших продуктов, в том числе партнерских инструментов. Создание идеального виджета — это искусство, и вы можете приобщиться к нему вместе с докладом Игоря Вечканова, программиста Travelpayouts. В рамках Front Fest Moscow Игорь поделился опытом создания пуленепробиваемого виджета. В этом материале вы найдете презентацию доклада, полную видеозапись выступления и короткую выжимку информации.


Виджеты Travelpayouts

Один из самых популярных виджетов Travelpayouts — поисковая форма Aviasales. Существует более 18 тысяч различных конфигураций данной формы, которые распространены по тысячам сайтов.

Виджеты Travelpayouts.jpg

Помимо основного виджета партнерам доступно 8 других, а также White Label — т.е. у партнеров есть возможность встроить полноценный поисковый движок к себе на сайт.

При разработке виджета важно учитывать, что он должен быть:

  • легким и быстрым;
  • работающим.

Скорость загрузки и быстродействие — важный параметр. Но также важно, чтобы все стабильно работало.

Отличия разработки виджетов от других проектов

  • Размер;
  • Агрессивная среда размещения;
  • Локализации + кастомизируемость;
  • Время на разработку.

Размер влияет не только на скорость загрузки страницы партнера, но и на предпочтения аффилиатов. Некоторые могут перейти к конкурентам, т.к. их продукты легче и быстрее.

При разработке никогда неизвестно, где именно будет размещаться виджет и какой код будет исполняться на странице. Продукт должен работать везде, независимо от контекста.

Локализация встречается и в других проектах, но кастомизируемость — возможность тонкой настройки пользователем, это специфичный момент.

Как бы ни хотелось тратить на разработку меньше времени, это не всегда возможно. Многим разработчикам кажется, что продукт можно разработать за несколько дней на Реакте. Но практика показала, что к вопросу стоит относиться иначе.

Основные проблемы разработчиков

При приеме в команду Travelpayouts еще одного фронтендера в качестве тестового задания было необходимо сделать простой виджет:

Основные проблемы разработчиков.jpg

Это очень простая форма — она может менять цвета и подстраиваться под ширину. В качестве факультатива кандидатам требовалось интегрировать pop-up data-picker.

Среди работ соискателей встречались дистрибутивы по 200 кб, что было неприемлемо, помимо этого были и другие проблемы:

  • Неизолированные стили;
  • Непродуманный код для вставки.

Как уместить виджет в 50Кб

Форма авиабилетов и отелей — это главный виджет компании. Это то, что большинству пользователей хочется установить в первую очередь сразу после регистрации. Продукт был разработан 1,5 года назад, после чего вносились лишь небольшие изменения и в целом код работает максимально стабильно. Разработчикам удалось добиться следующих результатов:

  • 45кб js + 10кб CSS + 7кб Logo = 55кб + 7кб;
  • Эффективность, вымученная а/б тестами;
  • Почти не было жалоб от партнеров после деплоя на 100%.

Размер 55–62 Кб — это показатель после Gzip сжатия. Предыдущая версия, созданная 4 года назад, весила около 100Кб.

Небольшого размера удалось добиться благодаря отказу от использования фреймворков. Для создания использовался NPM. Благодаря Babel-plugin-lodash / submodules / lodash-es можно подключить лишь те библиотеки, которые действительно используются при работе.

Размер можно снизить еще, если использовать date-fns / js-joda вместо moment.js, так как они обладают модульностью.

При разработке используется шаблонизатор Monkberry.js, который разработан внутри Aviasales, но сейчас доступен для всех.

Чтобы оставаться в рамках 50 килобайт необходимо проводить постоянный контроль итогового размера дистрибутива, в этом помогает:

  • Size Limit;
  • Webpack bundle analyzer;
  • Jsize.

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

Проблемы с CSS

При разработке необходимо учитывать особенности CSS. Со стилями связаны следующие проблемы:

  • Коллизия имен классов;
  • Глобальное переопределение свойств;
  • Более сильные селекторы.

Все это может разломать форму на сайте партнера. Чтобы избежать этих проблем необходимо изолировать стили.

Код для вставки

Любое усложнение кода приводит к дополнительным запросам в службу поддержки. Вместо связки script + div#id остановились лишь на скрипте. Это избавило вебмастера от необходимости думать, где в собственном коде расположить блоки.

Оптимальный способ передачи параметров — кэшировать выбранные параметры прямо в код виджета по хэшу с возможностью их переопределения инлайновым js.

Айфреймы выглядят как хорошее решение, так как обладают полной изоляцией контента и отсутствием проблем с кросс-доменными запросами, но при этом у них есть и минусы:

  • Низкая скорость загрузки;
  • Невозможность выйти за границы айфрейма;
  • Сложность кастомизации для вебмастера.

Настройка виджета

Требуется создать генератор, чтобы у пользователя была удобная возможность задать настройки. Генератор включает в себя:

  • Настройки;
  • Демовиджет;
  • Код для вставки.

Нужно сделать обновление демо-виджета на лету.

Советы, как сделать идеальный виджет

  • Следите за размером дистрибутива;
  • Изолируйте CSS;
  • Предотвращайте возможность конфликта версий js-библиотек;
  • Разрабатывайте виджеты, моментально готовые к работе после загрузки;
  • Помните про iframe и локализации;
  • Делайте максимально простой код для вставки.

С полной версией презентации можно ознакомиться по ссылке.

Зарегистрируйтесь в Travelpayouts сейчас и получите повышенную комиссию 70% от дохода Travelpayouts сроком на 2 месяца.

Оригинал

0
0

Есть о чем рассказать? Тогда присылайте свои материалы в редакцию.


Новые 
Новые
Лучшие
Старые
Сообщество
Подписаться 
Подписаться на дискуссию:
E-mail:
ОК
Вы подписаны на комментарии
Ошибка. Пожалуйста, попробуйте ещё раз.
Отправить отзыв
    ПОПУЛЯРНЫЕ ОБСУЖДЕНИЯ НА SEONEWS
    Тест: Кто как пробежал, или Итоги клиентского рейтинга SEOnews 2018
    Анна Макарова
    335
    комментариев
    0
    читателей
    Полный профиль
    Анна Макарова - Друзья, спасибо всем за участие! Мы определили победителей. Кто ими стал - вы найдете по ссылке: www.seonews.ru/events/darim-knigi-ot-mif-pobediteli-opredeleny/ Если вы стали одним из победителей, обязательно свяжитесь с нами по указанной в новости (по ссылке выше) почте. Всем хороших выходных! =)
    32 инструмента в помощь SEO-специалисту
    luthorscorploanfirm
    2
    комментария
    0
    читателей
    Полный профиль
    luthorscorploanfirm - Я - г-н Марк Джо из корпорации corp, мы являемся законной, зарегистрированной и гарантированной кредитной компанией, мы предоставляем 3% -ые кредиты частным лицам, компаниям, государственным учреждениям и деловым организациям и людям всех родов. Свободные кредиты - это решение всех ваших финансовых проблем. свяжитесь с нами по электронной почте: mjoe0123@gmail.com
    SEO глазами клиентов 2018
    Гость
    1
    комментарий
    0
    читателей
    Полный профиль
    Гость - То есть *** пойми кто подался заявками и в итоге рейтинг должен называться seo глазами клиентов *** пойми каких компаний. Молодцы!
    Комплексный аудит интернет-магазина от «Ашманов и партнеры». Часть 1
    Александр Сова
    1
    комментарий
    0
    читателей
    Полный профиль
    Александр Сова - А вот и сеошники подъехали, покидать на вентилятор :D
    Не очень удачный кейс продвижения сайта по услуге «Трезвый водитель» в Москве
    Кирилл Щербаков
    3
    комментария
    0
    читателей
    Полный профиль
    Кирилл Щербаков - "даже пришлось подключить отслеживание звонков с сайта" "Даже" - как будто это что-то нереальное
    Два идеальных способа разориться на старте интернет-магазина
    Стас
    4
    комментария
    0
    читателей
    Полный профиль
    Стас - Seonews в последнее время такую чушь несет! Где вы таких афторов находите? Статья ничего не стоит и несет чушь! Кто хоть немного понимает в этом так вам и скажет, и такие де комментаторы горе-сеошники, просто смешно читать, вы хоть модерируете ваши статьи или просто для воды на сайте?! Бред сивой кобылы эта статья до самой последней точки!!!
    Эксперимент: как уникальность контента влияет на продвижение сайта
    Ilia Nazmutdinov
    2
    комментария
    0
    читателей
    Полный профиль
    Ilia Nazmutdinov - Кстати, ПФ не работают на нулевом трафике. Пока на сайт не льются тысячи показов по одним и тем же запросам влияние оказывает ток ссылочное\внешнее и внутреннее\ и внутренняя оптимизация.
    Яндекс перестал индексировать сайты, созданные на Wix
    Константин Даткунас
    3
    комментария
    0
    читателей
    Полный профиль
    Константин Даткунас - Было бы интересно посмотреть саму выборку из 10 000 и методику анализа.
    Расчет трафика из поисковых систем по брендовым и небрендовым запросам
    Дарья Калинская
    238
    комментариев
    0
    читателей
    Полный профиль
    Дарья Калинская - А вот и статья :) www.seonews.ru/analytics/raschet-trafika-po-nebrendovym-zaprosam-pri-pomoshchi-r/
    Как мы разработали и вывели в ТОП сайт курсов рисования
    Иван Стороженко
    25
    комментариев
    0
    читателей
    Полный профиль
    Иван Стороженко - Добрый день. 1)Чаще всего основная проблема заключается, в согласовании с клиентом добавляемого контента и то как он будет отображаться. На данном сайте фото и услуги конечно предоставлял клиент, все остальное уже делали мы. 2)Да в принципе, когда есть команда и понимание, что нужно делать, все идет быстро (опять же основная заминка идет на согласовании с клиентом) 3)Смысла делать новый в данном случает нет. В принципе доделывался полноценный сайт. 4)Когда клиент уже не предоставляет информацию, приходится искать у конкурентов (например с других стран или регионов). Но чаще всего клиент, хоть что-то "подкидывает".
    ТОП КОММЕНТАТОРОВ
    Комментариев
    910
    Комментариев
    834
    Комментариев
    554
    Комментариев
    540
    Комментариев
    483
    Комментариев
    373
    Комментариев
    335
    Комментариев
    262
    Комментариев
    238
    Комментариев
    171
    Комментариев
    156
    Комментариев
    137
    Комментариев
    121
    Комментариев
    97
    Комментариев
    97
    Комментариев
    95
    Комментариев
    87
    Комментариев
    80
    Комментариев
    67
    Комментариев
    60
    Комментариев
    59
    Комментариев
    59
    Комментариев
    57
    Комментариев
    55
    Комментариев
    54

    Отправьте отзыв!
    Отправьте отзыв!