Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Профессия "Front-end архитектор"
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Andrey Okonetchnikov
April 13, 2007
Programming
170
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Профессия "Front-end архитектор"
Andrey Okonetchnikov
April 13, 2007
More Decks by Andrey Okonetchnikov
See All by Andrey Okonetchnikov
Component-Driven Design Systems Workshop
okonet
0
240
A Common Design Language
okonet
2
2.1k
Make Linting Great Again (Long version)
okonet
0
110
Modular CSS v2 (CSS-in-JS edition)
okonet
3
1.1k
Make Linting Great Again
okonet
0
190
Modular CSS — Agent Conf '17 Edition
okonet
3
410
Modular CSS
okonet
3
300
JavaScript для насыщенных пользовательских интерфейсов
okonet
0
140
Other Decks in Programming
See All in Programming
LLMによるContent Moderationの本番運用の裏側と品質担保への挑戦
suikabar
3
790
スマートグラスで並列バイブコーディング
hyshu
0
260
ADKを使って簡単にAIエージェントを作ってみよう
k1mu21
0
280
任せる範囲はこう広がった / How the Scope of AI Delegation Has Expanded
nrslib
0
150
技術記事、 専門家としてのプログラマ、 言語化
mizchi
13
6.6k
Signal Forms: Details & Live Coding @enterJS 2026 in Mannheim
manfredsteyer
PRO
0
200
Semantic Version 単位で戦略を柔軟に変えて、パッケージアップデートを自動化する
daitasu
1
310
Datadog × OpenTelemetry 入門と実践のあいだ
kn_to_maxpno
1
180
TSKaigi Night Talks 2026_TypeScriptでサプライチェーンの整合性を型に閉じ込める
geekplus_tech
0
410
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
560
Vite+ Unified Toolchain for the Web
naokihaba
0
360
The NotImplementedError Problem in Ruby
koic
1
960
Featured
See All Featured
Designing for humans not robots
tammielis
254
26k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
Designing Experiences People Love
moore
143
24k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
659
62k
A designer walks into a library…
pauljervisheath
211
24k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
123
22k
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
2
1.6k
What Being in a Rock Band Can Teach Us About Real World SEO
427marketing
0
1k
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
790
Tips & Tricks on How to Get Your First Job In Tech
honzajavorek
1
540
Being A Developer After 40
akosma
91
590k
We Are The Robots
honzajavorek
0
260
Transcript
Профессия «front-end архитектор» © Андрей Оконечников, 2007
Слово.
Слово.
Слово.
spacer.gif
И началась эпоха веб-дизайнеров.
Дизайнер- ремесленник
Фокусируясь на том, как сайт выглядит, дизайнеры часто забывают о
целях и задачах.
Cайтом должны пользоваться люди,
искать и находить,
делать покупки,
читать новости,
участвовать в обсуждениях.
Стремление быть оригинальными приводит
к необычным результатам...
None
None
None
None
None
Дизайн ради дизайна
не ради пользователей
не ради их целей и задач
не ради удовлетворенности продуктом или услугой
10 фишек
Почему так происходит?
Очень часто дизайнеры думают...
результат их работы — самый важный.
Это не так!
Графический дизайн — лишь один из аспектов веб-разработки.
Такой же, как
usability,
accessibility,
семантика,
и контент.
Немногие дизайнеры пишут код разметки страниц.
Поэтому...
После создания макетов, дизайнер выводится из проекта,
а реализацией занимаются другие люди...
Дизайнер теряет контроль над конечным продуктом.
None
None
Можно относиться к дизайну как к искусству,
но это имеет мало общего с реальным миром и его
потребностями.
+
Низкое качество разметки страниц
=
Source: http://www.accessibility.nl/files/images/tag-soup2-035.jpg
Source: http://andyhiggs.co.uk/blog/images/162.jpg
Веб-стандартист
Появились люди, называющие себя «веб-стандартисты» и выступающие…
создание семантического и валидного кода
разделение представления и содержания
использование безтабличной верстки
Веб-сообщество приняло их как реальное решение накопившихся проблем.
Дизайнеры заявляют:
«Веб-стандарты, не являясь выразительным средством коммуникации, мешают их творческой работе»
Графический дизайн не зависит от веб-стандартов!
Source: http://www.uwsp.edu/geo/faculty/ritter/images/maps/ocean_currents.jpg
Source: http://www.photos-screensaver-maker.com/screen/images/scr-ocean.jpg
Выверенный и хорошо выполненный графический дизайн действует на пользователей лишь
через визуальный канал.
Семантическая разметка, на которую «наложена» графическая составляющая, будет взаимодействовать с
технологиями и механизмами Веба.
Создать уникальный графический дизайн и реализовать его, используя веб-стандарты, —
это реальная задача.
Кроме того...
хорошая разметка ускоряет разработку веб-приложений.
Source: http://www.webdimension.co.uk/
Время front-end архитекторов
Сегодняшняя веб- разработка немыслима без использования серверных фреймворков
None
None
призваны упрощать и ускорять разработку и отладку веб-приложений.
Усложняется логика работы приложений.
Растут объемы данных.
Это сделало стандартом «де-факто» наличие в проектах системного архитектора.
системный архитектор
Использование серверных фреймворков предполагает, что
разработчик должен больше думать о логике приложения, красоте своего кода,
его объектной модели
нежели о деталях реализации под различными браузерами и платформами.
Но!
Результат работы фреймворка не всегда идеален и зачастую должен быть
откорректирован.
None
C развитием серверных фреймворков, становятся все более сложными и фронт-енд
технологии.
и динамическое изменение страниц, Ajax
drag & drop
визуальные эффекты
сложные элементы пользовательского интерфейса
+
user experience
usability
accessibility
современные задачи уже не могут быть решены лишь с помощью
HTML & CSS
безтабличной версткии
умением писать валидный код
Front-end архитектура
Учитывая то количество различных технологий и способов решения тех или
иных задач
часто бывает сложно принять решение, какой из этих способов следует
использовать в данном конкретном случае.
— Использовать CSS или JavaScript для создания выпадающих меню?
— Использовать текстовые, графические или sIFR загловки?
Каждый из способов имеет свои плюсы и минусы, которые могут
иметь разное значение в зависимости от конкретной ситуации.
Необходимо знать не только слабые и сильные стороны технологии, но
и владеть ситуацией.
Для принятия правильного решения
требуется человек, способный оценить ситуацию в целом, учитывая большое количество
факторов:
usability
accessibility
серверную реализацию
задачи пользователей
бизнес-цели
Разметка страниц
Основой фронт-енда является HTML разметка страниц.
— Какой doctype стоит использовать?
— Каким (x)HTML элементом кодировать тот или иной блок на
странице?
— Использовать атрибут id или class?
Это зависит от...
Какой серверный фреймворк будет использоваться?
Какая функциональность будет на страницах?
Потребуется ли менять внешний вид страниц?
CSS
CSS является презентационным уровнем фронт-енд модели приложения.
— Как организовать CSS документы?
— Создавать имена классов или привязать к элементам DOM?
— Использовать наследование или писать дублирующий код?
Это зависит от...
Насколько крупное создается приложение?
Будет ли меняться разметка страниц в процессе разработки?
Как взаимосвязана функциональность страниц?
JavaScript
JavaScript & DOM scripting — это логика фронт-енд приложения.
— Использовать onclick или “unobtrusive” обработчики событий для элементов?
— Реализовать валидацию на стороне клиента или сервера?
— Назначать стиль отображения inline через JavaScript или использовать className?
— Организовать код через namespaces или использовать global scope?
Это зависит от...
Что решает эта функциональность?
Как именно она должна работать?
Поддерживают ли данную реализацию необходимые браузеры?
Существуют определенные практики, знание и владение которыми позволит избежать множества
проблем при использовании JavaScript.
Ajax
Полный Ajax!
— Использовать Ajax или стандартный механизм с обновлением страницы?
— Какой из вариантов наиболее удобен для пользователей в контексте
решаемой задачи?
— Как это отразится на доступности приложения?
— Смогут ли использовать эту функциональность пользователи мобильных устройств?
Это зависит от...
Если отключен JavaScript, то Ajax функциональность перестанет работать.
Этот недостаток можно обойти, но это потребует дополнительных усилий.
И снова требуется кто-то, кто сможет дать рекомендации по использованию,
кто сможет принять решение о необходимости Ajax в конкретном случае.
Front-end архитектор
front-end архитектор
None
None
None
None
None
Какими знаниями и навыками должен обладать фронт-енд архитектор?
XHTML & CSS
Кросс-браузерная и кросс-платформенная совместимость
JavaScript разработка (DOM scripting, Ajax, UI)
Flash & ActionScript
Progressive Enhancement & Graceful Degradation
Accessibility
Usability
Информационная архитектура
Дизайн пользовательских интерфейсов
Визуальный дизайн
Логика генерации страниц (ASPX, Rails Views, etc.)
Бизнес-логика
• XHTML & CSS • Кросс-браузерная и кросс-платформенная совместимость •
JavaScript разработка (DOM scripting, Ajax, UI) • Flash и ActionScript • Progressive Enhancement & Graceful Degradation • Доступность использования (Accessibility) • Удобство использования (Usability) • Информационная архитектура • Дизайн пользовательских интерфейсов • Визуальный дизайн • Логика генерации страниц (ASPX, Rails Views, etc.) • Бизнес-логика
+
Уметь общаться на языке разработчиков и принимать критические интеграционные решения.
Хороший клиентский код — это часть задачи.
Необходимо, чтобы код взаимодействовал с серверной частью в реальных условиях.
Фронт-енд архитектор должен
владеть ситуацией на высоком уровне
уметь оценить преимущества и недостатки
руководствуясь множеством факторов.
None
Умение писать код,
проектировать пользовательские интерфейсы,
владеть современными технологиями,
следить за их развитием
обязательные качества специалиста.
Будущее профессии
Пусть этим занимаются системные архитекторы?
Системные архитекторы поглощены техническими аспектами разработки.
Когда такие профессионалы будут востребованы?
Вчера!
Обязательно ли это связано с интернетом и «социальными» или «Веб
2.0» сервисами?
Отнюдь!
Российский рынок труда
Компании не доверяют многопрофильным специалистам и предпочитают нанимать узконаправленных фронт-енд
специалистов:
графических дизайнеров,
кодировщиков HTML/CSS,
JavaScript разработчиков.
Но!
они не смогут решить 100% возникающих проблем.
Спрос на фронт-енд архитекторов появится в ближайшее время.
Кто-то должен управлять узкопрофильными специалистами, координировать их действия, отвечая за
конечный результат.
А что сейчас?
В настоящий момент явного спроса на фронт-енд архитекторов в России
не существует.
«Многостаночник» не может хорошо владеть всеми заявленными знаниями.
Относительная дороговизна таких сотрудников.
Не уделяется должного внимания вопросам usability, user experience, accessibility...
Подводя итог
Современному фронт-енду требуются свои архитекторы.
Чем более сложные приложения будут разрабатываться,
тем больше эта потребность будет расти.
Отреагировать на изменения рынка — задача сегодняшних специалистов.
Спасибо за внимание.
Андрей Оконечников
[email protected]
© Андрей Оконечников, 2007