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
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
630
コンテキストの使い捨てをやめる — ビジネスルール駆動開発と miko —
ioki
0
240
AIで効率化できた業務・日常
ochtum
0
150
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.7k
生成AI時代にこそ効くGo | Why Go Works in the Age of Generative AI
mom0tomo
8
3.3k
dRuby over BLE
makicamel
2
390
エージェンティックRAGにAWSで入門しよう!
har1101
9
1.8k
その問い、本当に正しいですか?AI時代のエンジニアに必要な哲学と認知科学 / ai-philosophy-cognitive-science
minodriven
14
6.3k
エンジニア向け会社紹介/Findy Company Profile
findyinc
6
350k
そのテスト、説明できますか?~LWテスト戦略FW~のご紹介
nakahara
0
170
セキュリティの専門家じゃなくてもできる。「セキュリティ意識」をアップデートして サプライチェーン攻撃への耐性を高めよう。
tk3fftk
5
970
気づいたらRubyで100作品 ー クリエイティブコーディングが生活の一部になるまで / 100 Ruby Sketches Later: How Creative Coding Became Part of My Life
chobishiba
3
610
Featured
See All Featured
Prompt Engineering for Job Search
mfonobong
0
350
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.8k
Navigating the Design Leadership Dip - Product Design Week Design Leaders+ Conference 2024
apolaine
1
360
The Language of Interfaces
destraynor
162
27k
Odyssey Design
rkendrick25
PRO
2
710
Balancing Empowerment & Direction
lara
6
1.2k
sira's awesome portfolio website redesign presentation
elsirapls
0
290
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
620
Test your architecture with Archunit
thirion
1
2.3k
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
190
Have SEOs Ruined the Internet? - User Awareness of SEO in 2025
akashhashmi
0
370
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
123
22k
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