Приложение Маяки Эстонии
2 Декабря

Не щадя живота своего...

... сражался я с ветряными мельницами. Причём невидимыми... Началось всё с просмотра этого видео. Ничего глобально нового не узнал, но вот приоритеты точно сменил. Проверил я свой родной сайт в Google PageSpeed. Полученный результат, мягко говоря, опечалил: 33 балла (из 100 возможных) для мобильной версии и 56 для десктопной. Дальше произошло самое неожиданное: вместо уныния меня переполнил чуждый мне перфекционизм и битва за урожай началась. Без малого 3 дня я экспериментировал на грани извращений. Сейчас показатели следующие: 80 баллов для мобильной версии и 86 для десктопной. Не безоговорочная, но всё же победа!

Все сделанные мной изменения (за одним исключением) внешне не видны. Итак, что же конкретно было сделано:

  • включено сжатие Gzip (в файле .htaccess)
  • включено кэширование для графики и шрифтов (в файле .htaccess)
  • убран весь инлайн JavaScript, что позволило перенести подключение библиотеки Jquery из хедера в футер (ну или "из чердака в подвал", если вам так больше нравится). Весь остальной JS и так уже был в футере.
  • минифицированы все CSS- и JS-файлы. Затем мне и этого показалось мало и чтобы уменьшить количество запросов, я объединил их в 2 файла - all.min.css и all.min.js
  • для мобильных устройств вся графика в новостях теперь ресайзится специальным скриптом, а полная версия открывается в Фэнсибоксе
  • вся графика в дизайне с формата GIF заменена на PNG. Это и есть то самое визуально заметное изменение, так как у фона-пергамента появилась тень
  • вся графика в формате PNG была ужата

На этом фантазия меня оставила, да и силы тоже. Ещё неплохо бы полностью перелопатить CSS и сделать его mobile first, но не сейчас и, скорее всего, не в этом году.

5 Августа

Наконец-то я могу сказать это: я закончил и запустил новую версию "Пейнтбольного камикадзе". Что нового? Классный дизайн, адаптивная вёрстка и WordPress в сердце. Самое главное на этом сайте - мои анимированные схемы, поэтому им уделено больше всего внимания. Раньше все они были на Flash, что делало анимацию плавной и приятной, но схемы совершенно не отображались почти на всех мобильных устройствах. Сейчас Flash показывается там, где это возможно, а где невозможно - анимированный GIF. Так что, вэлкам все!

10 Июня

Мэйджор техникл апдейт

Данный сайт почти всегда был для меня площадкой для разного рода экспериментов по программированию. Правда последние год-полтора мне и на работе этого всего хватает и здесь "под капот" я лажу всё реже и реже. Последнее серьёзное обновление было сделано более года назад, когда сайт полностью сменил движок. Тогда же вёрстка была переделана под адаптивную. Надо сказать, что адаптивной вёрстке я тогда только учился и в итоге не всё на этом сайте было сделано "по уму".

Буквально час назад я зарелизил новую версию сайта с полностью переделанной вёрсткой и небольшими изменениями в backend`е. А теперь подробнее что и зачем:

  • Убран 1 из 4 брейкпоинтов адаптивной вёрстки и внесены изменения в оставшиеся 3. Например, блок комментариев и нижний параллакс теперь показываются на всех разрешениях.
  • Полностью переработано главное меню сайта. Flash-версия с фонариками ушла безвозвратно.
  • Переделана и смещена вправо (чтоб читать не мешала) кнопка возврата наверх страницы.
  • Верхний (логотип с кандзи) и нижний (пейзаж) параллаксы, а так же страница ошибок переделаны под использование скрипта parallax.js, который помимо всего прочего отлично работает на мобильниках и планшетах.
  • Многие иконки заменены на шрифтовые от Font-Awesome. В первую очередь для чёткости на retina-экранах.
  • Заменены кнопки шаринга в соцсетях. Теперь они есть под каждым постом в ленте и ссылаются на конкретный пост или статью.
  • Пагинация (оказывается, теперь и в русском это слово есть) стала занимать слишком много места и была переделана. Теперь в одну строку и с горизонтальной прокруткой.
  • Из галереи убраны некоторые альбомы, которые сейчас кажутся слишком личными.
  • Подгрузка картинок в галерее сделана через infinite scroll. Собственно, я изначально так и хотел, но прошлый раз что-то не сдюжил и в итоге появилось непонятное решение с подгрузкой по ссылке.
  • Убрана страница контактов. Совершенно бесполезный придаток. Позднее сделаю какую-нибудь возможность связи.
  • Обновлён скрипт комментариев до версии 5.2.11. Если честно, он уже давно бесит меня, но не меняю я его потому, что не хочется терять все добавленные комментарии.
  • Оптимизирован весь JavaScript.
  • Картинки из старых новостей и статей теперь будут скэйлиться с сохранением пропорций.
  • Добавлена небольшая copyright-фича.

20 Февраля

Надоело синячить без повода, надо куда-то на сайт вот такую штуку прикрутить:

Праздники сегодня

13 Сентября Сегодняшний пост будет полностью программистски-биографичным. Возражать не имеете права, сегодня наш праздник - день программиста. Программист я исключительно web-ориентированный (сайтики делаю). Занимаюсь я этим уже более 10 лет. За это время я поработал (неофициально) в двух фирмочках, но большую часть проектов делал фрилансом. "Халтурил" я в основном для знакомых и знакомых знакомых, что в общем-то плохо, ибо расценки "по знакомству" явно ниже средних, а отношение к исполнителю "свойское". Все клиенты - небольшие компании, которые хотят сделать сайт предельно дёшево и при этом готовы жертвовать качеством в разумных пределах. Последнее нагляднее всего выражается в том, что зачастую мне заказывают и дизайн. Вы заказываете сантехнику кровельные работы? А рыбаку приготовление пойманной им рыбы? Так же и в разработке сайтов.

И хотя работаю я не в России, несколько случаев "кидалова" было. Примечательно, что в двух из них клиент вообще отказывался от сайта как такового. В смысле, вообще не нужен ни сейчас, ни потом. А раньше чем думали, когда меня искали, когда со мной всё обсуждали, когда подтверждали ТЗ? Пару раз было так, что разработку со стороны заказчика сайт принимали 2-3 человека и давали взаимоисключающие корректировки. Причём, как всегда в таких случаях бывает, давали они их не одновременно, так что приходилось делать, переделывать, переделывать ещё раз и т.д.

Впрочем, самая больная проблема web-программирования в изменении пожеланий и требований заказчика в процессе разработки.

- Мы делаем это?
- Потом решим, делай пока основное
А если это для меня и есть самое основное?.. И таких примеров не счесть. Хуже всего, что заказчик не понимает, что реализации его новой "фишки", о которой он ни словом не обмолвился ранее, займёт некоторое время, на которое у меня были другие планы. По этому логичная в таком случае просьба об увеличении бюджета сайта нередко вызывает негодование у заказчика. Конечно, по его мнению я просто сижу за компьютером, это и работой-то назвать нельзя. Более того, некоторые заказчики считают, что создание сайтов - плёвое дело и они запросто смогли бы сдюжить его сами, но нет времени. Я уже выкладывал тут один ролик, очень наглядно показывающий данную ситуацию. Когда я его в первый раз смотрел, было совершенно несмешно, потому что слишком уж правдиво.

В случае очень простых сайтов, бывает так, что клиент (опять же в целях экономии) заказывает просто статичные страницы без возможности изменить их содержание. Чтож, как будет угодно. Потом, через годик-другой, этот заказчик возвращается и просит подредактировать список услуг и цен или какие-то данные в таблице и потом очень удивляется цене на это. Причины две: 1) в прошлый раз всё так дёшево было и 2) тут всего-то надо немножко подправить. А чего ты хотел, прошлый раз ты купил упаковку без содержимого.

Подытожив, могу сказать, что работа программиста (из всех, кто участвует в создании веб-проекта) хоть и не самая сложная (дизайнерам зачастую сложнее), но самая геморройная. В ней больше всего подводных камней и неприятных сюрпризов, появляющихся тогда, когда, казалось бы, уже виден финиш.

Для меня лично, бОльшая часть этих проблем в прошлом, так как я работаю в более-менее крупной фирме. Учитывая, что я на окладе, я могу месяцами переделывать, добавлять, менять и т.д. Правда и от фриланса я полностью не отказался, хотя для меня он уже совсем не такой, как раньше. И, напоследок, немного личного опыта для тех, кому это может пригодиться.

Пара советов программистам. Заказчик сам точно не знает чего он хочет, а если и знает, то редко когда может доходчиво это объяснить. Он не тупой, просто это не его специфика. Поэтому сами создавайте предельно подробное, но удобоваримое для клиента ТЗ (техническое задание). Таким образом вы минимизируете непонимание и двусмысленность между вами и заказчиком, а так же избавите себя от "новых фич" на окончательной стадии разработки. Новые пожелания в таком случаю приведут к изменению ТЗ и вам проще будет объяснить заказчику, за что вы просите дополнительную плату. Ещё одни "грабли" - совместимость сайта со старыми версиями браузеров. Нередко в ТЗ это не фигурирует, а заказчик потом просит исправить "некорректное отображение в IE7", а для этого сайт надо неслабо перелопатить. Ещё один плюс в составлении ТЗ - упрощение составления бюджета. Имея на руках подробное задание, подтверждённое заказчиком, несложно подсчитать время, которое потребуется на выполнение и, как следствие, цену. Опять же и заказчику в этом случае цену объяснить будет легче.

Пара советов заказчикам. Первое и самое главное - выбирайте опытного программиста. Выбрав из желания сэкономить студента-первокурсника, вы обрекаете себя на то, что проблемы в процессе разработки будут расти, как снежный ком. Такой исполнитель выполнит все ваши требования, но не предложит какого-то решения лучше или, что бывает гораздо чаще, использует не максимально подходящий CMS или фрэймворк, а тот, который знает сам. Поддержка или обновление проекта впоследствии с таким программистом тоже зачастую бывают проблемными: в большинстве случаев его просто не найти (поверьте, это случается гораздо чаще, чем вы думаете). Иная ситуация с профессиональным программистом: они и знает, как и что лучше, и впоследствии его обычно несложно найти. Тут главное - не мешать. Если он что-то говорит/предлагает, на это есть свои причины. Вы же не учите автомеханика, как чинить вам машину, доверьтесь профессионалу и в этом случае.

Цитировать
в комментарии