@witchfinderx
3
Илья Пухальский,
EPAM Mobile Competency Center
Slide 4
Slide 4 text
Правда действительности
— Мобильный веб существует
— HTMLx не будет готов никогда
4
Slide 5
Slide 5 text
http://play.freeciv.org
Slide 6
Slide 6 text
No content
Slide 7
Slide 7 text
No content
Slide 8
Slide 8 text
Веб-приложения
Slide 9
Slide 9 text
9
?
Slide 10
Slide 10 text
10
"...a Web page (XHTML or a variant thereof + CSS) or collection of
Web "pages delivered over HTTP which use server-side or client-
side "processing (e.g. JavaScript) to provide an "application-like"
"experience within a Web browser."
http://www.w3.org/TR/mwabp/#webapp-defined
Slide 11
Slide 11 text
11
!==
Ориентировано на
задачи
Ориентирован на
контент
Slide 12
Slide 12 text
Может это вообще не нужно?
Slide 13
Slide 13 text
No content
Slide 14
Slide 14 text
North American Development Survey: Vol. II, Evans Data Corp.
Slide 15
Slide 15 text
No content
Slide 16
Slide 16 text
Как так вышло?
Slide 17
Slide 17 text
DHTML
1997
Slide 18
Slide 18 text
AJAX
1999
Slide 19
Slide 19 text
JSONP
2005
Slide 20
Slide 20 text
2005
Slide 21
Slide 21 text
2006
Slide 22
Slide 22 text
22
2007
Slide 23
Slide 23 text
23
Slide 24
Slide 24 text
2007
Slide 25
Slide 25 text
2008
Slide 26
Slide 26 text
2008
Slide 27
Slide 27 text
2009
Slide 28
Slide 28 text
2009
Slide 29
Slide 29 text
2010
Slide 30
Slide 30 text
Look ma, no backend!
Slide 31
Slide 31 text
No content
Slide 32
Slide 32 text
RISES AGAIN
Slide 33
Slide 33 text
Проблемы
Slide 34
Slide 34 text
Доступ к возможностям
устройства
Slide 35
Slide 35 text
Сложная архитектура
приложения
Slide 36
Slide 36 text
Тач-события и жесты
совместно с другими
устройствами ввода
Slide 37
Slide 37 text
Скроллинг и sticky-элементы
Slide 38
Slide 38 text
Анимации
Slide 39
Slide 39 text
Дополнительные элементы
интерфейса
Slide 40
Slide 40 text
Эмуляция внешнего вида
и поведения
native-приложений
function handleFileSelect(evt) {
var files = evt.target.files; //
FileList object
for (var i = 0, f; f = files[i]; i++)
{
console.log(f.size,
f.lastModifiedDate);
}
document.getElementById('files')
.addEventListener('change',
handleFileSelect, false);
Slide 52
Slide 52 text
Drag and Drop
Slide 53
Slide 53 text
document.getElementById('id').addEventListener('drag',
function (e) {
e.dataTransfer.setData("Text", e.target.id);
});
document.getElementById('id').addEventListener('drop',
function (e) {
e.preventDefault();
var data = e.dataTransfer.getData("Text");
e.target.appendChild(document.getElementById(data))
;
});