38
Драматическая история одной промостраницы Я.Субботник, Санкт-Петербург, 30 июня 2012 года Разработчик интерфейсов Олег Мохов

Олег Мохов "Драматическая история одной маленькой промостранички"

  • Upload
    yandex

  • View
    1.111

  • Download
    4

Embed Size (px)

Citation preview

Page 1: Олег Мохов "Драматическая история одной маленькой промостранички"

Драматическая история одной промостраницы

Я.Субботник, Санкт-Петербург, 30 июня 2012 года

Разработчик интерфейсовОлег Мохов

Page 2: Олег Мохов "Драматическая история одной маленькой промостранички"

Промостраницы

2

Page 3: Олег Мохов "Драматическая история одной маленькой промостранички"

3

• Одна-две страницы/макета

• Времени на разработку мало (1-3 дня)

• В обязанности одного разработчика входят обязанности двух-трех

Промостраницы

Page 4: Олег Мохов "Драматическая история одной маленькой промостранички"

4

Page 5: Олег Мохов "Драматическая история одной маленькой промостранички"

5

Page 6: Олег Мохов "Драматическая история одной маленькой промостранички"

6

Page 7: Олег Мохов "Драматическая история одной маленькой промостранички"

CSS3

Flash7

Page 8: Олег Мохов "Драматическая история одной маленькой промостранички"

html/css

xml/xsl шаблоны

серверный xml

javascript

8

Page 9: Олег Мохов "Драматическая история одной маленькой промостранички"

Страница очень тяжелая

9

Page 10: Олег Мохов "Драматическая история одной маленькой промостранички"

• Картинки уже были пожаты• Размер страницы 1.4 Мб

• Страница отрисовывается за 9-14 секунд на канале 1Мбит/сек (+ значительная задержка, т.к Турция)

Страница очень тяжелая

10

Page 11: Олег Мохов "Драматическая история одной маленькой промостранички"

1 итерация

Page 12: Олег Мохов "Драматическая история одной маленькой промостранички"

I итерация

• Ленивая загрузка картинок по window.load (.b-icon_carousel_3D → .b-icon_carousel-lazy_3D)

• CDN в Европе

12

Page 13: Олег Мохов "Драматическая история одной маленькой промостранички"

• Практически без изменений на старте загрузке

• –2-5 секунд (в первую очередь благодаря CDN) на окончании загрузки

13

I итерация

Page 14: Олег Мохов "Драматическая история одной маленькой промостранички"

2 итерация

Page 15: Олег Мохов "Драматическая история одной маленькой промостранички"

2 итерация• Cтатический блок «Поделиться»

• все <script> в конец <body>

• html-код попапов в конец страницы

• height/width для <img> (даже z.gif)

15

Page 16: Олег Мохов "Драматическая история одной маленькой промостранички"

16

Page 17: Олег Мохов "Драматическая история одной маленькой промостранички"

• Cтатический блок «Поделиться»

• Все <script> в конец <body>

• html-код попапов в конец страницы

• height/width для <img> (даже z.gif)

17

2 итерация

Page 18: Олег Мохов "Драматическая история одной маленькой промостранички"

• Статический блок «Поделиться»

• Все <script> в конец <body>

• HTML-код выпадушек в конец страницы

• height/width для <img> (даже z.gif)

18

2 итерация

Page 19: Олег Мохов "Драматическая история одной маленькой промостранички"

• Статический блок «Поделиться»

• Все <script> в конец <body>

• HTML-код выпадушек в конец страницы

• Height/width для <img> (даже z.gif)

19

2 итерация

Page 20: Олег Мохов "Драматическая история одной маленькой промостранички"

• –1-2 секунды для начала отрисовки

• –1-2 секунды на окончании загрузки (всего 3-7 секунд)

20

2 итерация

Page 21: Олег Мохов "Драматическая история одной маленькой промостранички"

21

Page 22: Олег Мохов "Драматическая история одной маленькой промостранички"

3 итерация

Page 23: Олег Мохов "Драматическая история одной маленькой промостранички"

• img0 (https://github.com/imgo/imgo)

23

3 итерация

Page 24: Олег Мохов "Драматическая история одной маленькой промостранички"

• Выиграли 300Кб за счёт картинок

24

3 итерация

Page 25: Олег Мохов "Драматическая история одной маленькой промостранички"

25

Page 26: Олег Мохов "Драматическая история одной маленькой промостранички"

26

Page 27: Олег Мохов "Драматическая история одной маленькой промостранички"

27

Page 28: Олег Мохов "Драматическая история одной маленькой промостранички"

28

Page 29: Олег Мохов "Драматическая история одной маленькой промостранички"

29

Page 30: Олег Мохов "Драматическая история одной маленькой промостранички"
Page 31: Олег Мохов "Драматическая история одной маленькой промостранички"

<!-- HTML --><body class=”csstransforms3d”>

// JavaScriptif (Modernizr.csstransforms3d)

31

Modernizr

Page 32: Олег Мохов "Драматическая история одной маленькой промостранички"

False positive bug32

Page 33: Олег Мохов "Драматическая история одной маленькой промостранички"

function supports3d() { // borrowed from modernizr var div = document.createElement('div'), ret = false, properties = ['perspectiveProperty', 'WebkitPerspective']; for (var i = properties.length - 1; i >= 0; i--){ ret = ret ? ret : div.style[properties[i]] != undefined; };

// webkit has 3d transforms disabled for chrome, though // it works fine in safari on leopard and snow leopard // as a result, it 'recognizes' the syntax and throws a false positive // thus we must do a more thorough check: if (ret){ var st = document.createElement('style'); // webkit allows this media query to succeed only if the feature is enabled. // "@media (transform-3d),(-o-transform-3d),(-moz-transform-3d),(-ms-transform-3d),(-webkit-transform-3d),(modernizr){#modernizr{height:3px}}" st.textContent = '@media (-webkit-transform-3d){#test3d{height:3px}}'; document.getElementsByTagName('head')[0].appendChild(st); div.id = 'test3d'; document.body.appendChild(div);

ret = div.offsetHeight === 3;

st.parentNode.removeChild(st); div.parentNode.removeChild(div); } return ret;} 33

Page 34: Олег Мохов "Драматическая история одной маленькой промостранички"

if ($.browser.webkit && !supports3d()){ $('html') .removeClass('csstransforms3d') .addClass('no-csstransforms3d'); Modernizr.csstransforms3d = false;}

34

Page 35: Олег Мохов "Драматическая история одной маленькой промостранички"

Мораль

Page 36: Олег Мохов "Драматическая история одной маленькой промостранички"

• Загрузка страницы почти везде ускорилась вдвое

• Размер страницы уменьшился почти на треть

• И чтобы сделать это потребовалось буквально два дня

36

Page 37: Олег Мохов "Драматическая история одной маленькой промостранички"

• http://webo.in/

• Часть динамики всегда может стать статикой

• Profilers

• imgo (https://github.com/imgo/imgo) и csso (https://github.com/css/csso/)

37

Page 38: Олег Мохов "Драматическая история одной маленькой промостранички"

Разработчик интерфейсов[email protected]: olmokhov

Олег Мохов