Фреймворки: Недалёкое Прошлое и Ближайшее Будущее
DESCRIPTION
Презентация доклада Андрея Саломатина на YaC 2014TRANSCRIPT
![Page 1: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/1.jpg)
ФреймворкиНедалёкое Прошлое и Ближайшее Будущее
Андрей Саломатин
![Page 3: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/3.jpg)
![Page 4: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/4.jpg)
Тёмные Времена
![Page 5: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/5.jpg)
0 %
1 %
2 %Firefox 12 %
IE 85 %
2006 Статистика использования браузеров
источник: TheCounter.com
4
![Page 6: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/6.jpg)
2006 StackOverflow и GitHub не существуют
5
![Page 7: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/7.jpg)
2006 Появляется надежда
6
![Page 8: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/8.jpg)
![Page 9: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/9.jpg)
Эпоха Возрожденияклиент-сайда
![Page 10: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/10.jpg)
2010-2011 Небольшие MV* библиотеки
8
![Page 11: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/11.jpg)
2011-2012 Монолитные фреймворки
9
![Page 12: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/12.jpg)
2013-2014 Компонентный подход
10
Polymer React
![Page 13: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/13.jpg)
2008-2014 Количество вопросов на StackOverflow
11
Октябрь 2008
0
15 000
30 000
45 000
60 000
ExtJS Backbone Knockout Angular Ember Meteor Polymer React
![Page 14: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/14.jpg)
2008-2014 Количество вопросов на StackOverflow
11
Сентябрь 2014
0
15 000
30 000
45 000
60 000
ExtJS Backbone Knockout Angular Ember Meteor Polymer React
![Page 15: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/15.jpg)
![Page 16: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/16.jpg)
Портретэпохи возрождения
![Page 17: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/17.jpg)
Техники
MV* архитектура Компонентный подход
Двухсторонние биндинги Реактивность
13
![Page 18: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/18.jpg)
MV* Архитектура• MVC, MVVM, MVP
• Просто начать
• Плохо масштабируется
• Backbone, Knockout, Angular
14
![Page 19: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/19.jpg)
Компонентный подход• Слабо-связанные переиспользуемые компоненты
• Инкапсуляция на уровне DOM, CSS, JS
• ExtJS, basis.js, React, Polymer, BEM
15
![Page 20: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/20.jpg)
Двухсторонние биндинги• Модель ⇄ представление
• Knockout, Angular, Polymer
• Проблемы с быстродействием
• Магия
16
![Page 21: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/21.jpg)
Реактивность
• Описываем зависимости
• Фреймворк следит и распространяет изменения
• Knockout, Meteor, React
17
![Page 22: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/22.jpg)
Портрет Эпохи
Фокус на:
• Архитектуру
• Сложные интерфейсы
• Реактивность
18
![Page 23: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/23.jpg)
Портрет Эпохи
Фокус на:
• Архитектуру
• Сложные интерфейсы
• Реактивность
19
![Page 24: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/24.jpg)
Портрет Эпохи
Фокус на:
• Архитектуру
• Сложные интерфейсы
• Реактивность
19
![Page 25: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/25.jpg)
![Page 26: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/26.jpg)
Изобретаембудущее
![Page 27: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/27.jpg)
Варианты развития
Модульные фреймворки Изоморфизм
Перенос данных на клиент
21
![Page 28: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/28.jpg)
Модульные фреймворки
• Возможность заменить логическую часть
• Возможность использовать часть отдельно от остального
• Ampersand.js, i-bem.js
22
![Page 29: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/29.jpg)
Изоморфизм• Один код на сервере и клиенте
• React, Meteor уже поддерживают
• Angular, Polymer никогда не будут поддерживать
23
![Page 30: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/30.jpg)
Перенос данных на клиент
• Описываем операции с данными, не транспорт
• Фреймворк синхронизирует клиент и сервер
• Offline First
• Hoodie, Swarm.js
24
![Page 31: Фреймворки: Недалёкое Прошлое и Ближайшее Будущее](https://reader033.vdocuments.net/reader033/viewer/2022052322/557cf8eed8b42a89158b4b4d/html5/thumbnails/31.jpg)
Ваши варианты?#yac2014 #frontend
25