Як прогресивні веб-програми знову роблять мережу чудовою

Алан Семенов

24 вересня 2017 · 13 хв читання

Прогресивні веб-програми - це одна з найгарячіших тенденцій веб-розробки на даний момент, де все більше людей охоче дізнаються про концепцію та технологію. Більшість статей на цю тему є або дуже низьким рівнем, і їх важко поглинути людям, що не є технічними, або, навпаки, дуже короткими та неглибокими. Ця стаття намагається досягти неможливого - поясніть концепцію PWA таким чином, щоб вона була привабливою та зрозумілою не лише для ІТ-спеціалістів, а й для тих, хто загалом цікавиться новинками та гарячістю веб-індустрії сьогодні.

прогресивні

Бути прогресивним - важко. Ви повинні постійно йти в ногу зі світом, що постійно змінюється, і добре знати про нові тенденції у мистецтві, моді, політиці, здоров’ї та їжі. Ви повинні мати можливість переказати Трампа від Обами. Знайте, що Мане і Моне - це не той самий хлопець, хоча обидва вони малювали речі. Готуйте, як Джеймі Олівер (або принаймні робіть вигляд, що готуєте їжу, хаотично розкидаючи їжу по вашій кухні). Покиньте гамбургери та кебаб на користь зеленого листя невідомого походження, яке навіть корови відмовляються їсти. Пийте коктейлі з тих самих листочків, намагаючись з усіх сил не кидати.

Бути прогресивним в ІТ-бізнесі ще складніше. На додаток до всього, що згадувалося вище, ви повинні мати можливість програмувати у всіх популярних фреймворках JavaScript, мати 50 футболок будь-якого відтінку сірого, розпізнавати кожного покемона по імені та не плутати IPA та APA зі SPA. Відростання бороди дасть вам додаткові бали в прогресивності (подвійні бали, якщо ви дівчина).

Якщо ви не 90-річний фермер з Техасу, то, впевнений, у вас є смартфон. Подивіться - ці кольорові квадратики на головному екрані називаються «рідними програмами». Їх називають «рідними», оскільки вони розроблені власним чином для операційної системи вашого смартфона (будь то iOS або Android або - не дай Бог - Windows Phone).

Якщо ви веб-розробник, то, швидше за все, ви створюєте веб-сайти. Але веб-сайти - це ооо 90-ті роки, сьогодні все стосується додатків. І, будучи прогресивним веб-розробником, ви, очевидно, не можете просто розробляти мобільні програми, ну, ну, мобільні програми - це ооооооооооооооооооооооооооооооооооооооооооооооо, Отже, це було лише питанням часу, коли з’явиться концепція Progressive Web Apps народився.

Розробка мобільних додатків завжди була цією «забороненою сферою», куди деякі з нас, веб-розробників, наважились зайти. Вам довелося б бути хардкорним бекенд-програмістом, який би знав Objective-C, Java або C ++ або, зовсім недавно, такі фреймворки, як Xamarin або Cordova, які дозволяють розробникам орієнтуватися на кілька мобільних платформ з однією кодовою базою. І тоді, звичайно, завжди є проблема зробити свою програму загальнодоступною (якщо ви коли-небудь намагалися розгорнути свою програму в Apple AppStore, тоді ви знаєте, що я маю на увазі) і підтримувати синхронізацію веб-сайту та всіх мобільних версій між собою.

Очевидно, що веб-розробники не були задоволені такою ситуацією. Вони невпинно бурчали з підвалів батьківських будинків, дехто навіть клявся кинути пити колу і їсти чіпси, поки проблема не буде вирішена. Одна безрозсудна душа навіть пообіцяла випрати свою ігрову футболку, але прийшла до тями, поки не було пізно. Тим часом багато розумних розумів усіма силами намагалися усунути дратівливий розрив між розробками Інтернету та мобільних пристроїв, поки нарешті в 2015 році Google не представив свою наступну найкращу ідею після вкладки Інкогніто в Chrome - концепцію прогресивних веб-програм.

Концепція блискуча своєю мужньою простотою. Ви розробляєте веб-сайт, який виглядає та поводиться точно так само, як рідний мобільний додаток, а це означає, що його можна додавати на головний екран смартфона, надсилати push-сповіщення, отримувати доступ до апаратного забезпечення пристрою і - найголовніше - працювати в автономному режимі. Так, ви чули добре - Progressive Web App працює так само гладко в хиткій мережі або взагалі без неї, як при повному доступі до Інтернету.

Але ... але ... як браузер може відкрити веб-сайт, не маючи доступу до нього в Інтернеті, можете запитати? Ну, вірте чи ні, але ваш браузер тепер має безліч цікавих функцій, яких ви ніколи не очікували б лише пару років тому, якщо, звичайно, ви не гордий та відданий користувач Netscape або Internet Explorer 6.

Такі сайти, як whatwebcando.today, можуть аналізувати API вашого браузера та показувати, які функції, доступні на мобільних пристроях, також підтримуються вашим браузером. Спробуйте - я впевнений, ви будете здивовані. Моя поточна версія Chrome (56) підтримує 33 із 36 функцій, а над іншими працюємо. Так, це було на моєму ноутбуці, але мобільні браузери не настільки відстають (особливо на платформі Android).

«Гаразд», ти думаєш, «отже, мій браузер підтримує всі ці функції - чудово. Але у мене на смартфоні стільки програм, якими я користуюся щодня, я не можу просто кинути їх і перейти на веб-програми ». Але ви, мабуть, і тут помиляєтесь.

Дослідження, проведене в 2015 році маркетингом.com, показує дивовижну статистику:

Користувачі мобільних пристроїв проводять на своєму пристрої 80% часу, використовуючи лише три найкращі програми

Це показує, що існує дуже висока ймовірність того, що кумедний додаток, який ви завантажили 5 років тому, щоб намалювати вуса на фотографії своєї свекрухи, з тих пір, швидше за все, не використовувався. Більшість із нас використовує лише декілька програм, таких як Facebook, Instagram, Pinterest, Twitter, програму зчитування пошти, якийсь погодний додаток, і все про це. І - сюрприз! - більшість із них також можуть функціонувати як веб-програми, набагато легші за розміром.

Додаток Facebook у AppStore важить до 300 мегабайт (і це без вмісту!). Але коли я відкрив свою стрічку Facebook у браузері, вона завантажила лише 3 Мб вмісту. Так, різниця в 100 разів.

Ще одним величезним недоліком мобільних додатків є їх відкриваність. Щоб завантажити програму з магазину, перш за все її потрібно знайти там (це означає, що ви повинні точно знати, що шукаєте, інакше доведеться просканувати безліч пропонованих лайна), натисніть «Завантажити», підтвердьте, погодьтеся з умовами, введіть свій пароль, дочекайтеся завантаження програми, дочекайтеся встановлення бла-бла-бла ... До того часу, коли все закінчиться, ви можете легко забути, що саме ви шукали для початку.

За словами Габора Челе, менеджера з продуктів у Google, у мобільному додатку кожен крок, який ви спонукаєте користувача виконати, перш ніж він отримає цінність від вашого додатка, коштуватиме вам 20% користувачів.

Наведена вище діаграма порівнює, скільки часу проходить у користувача від моменту, коли він виявив програму, до моменту, коли її фактично відкриває, в Інтернеті та на мобільному. Різниця становить 40 секунд, і це надзвичайно довгий час в Інтернеті. Краса веб-програми полягає в тому, що її надзвичайно легко знайти, як і звичайний веб-сайт - ви погуглите його, натиснете посилання, щоб відкрити його, і все, у вас є програма на вашому пристрої, готова до запуску.

У це важко повірити, але лише за рік з травня 15 по травень 2016 року кількість завантажень мобільних додатків у США зменшилась більш ніж на 20%.

Якщо ми розглянемо статистику кожного користувача, це ще смішніше. Згідно з повідомленням comScore, у Великобританії більше половини користувачів смартфонів щомісяця завантажують НУЛЬКІ програми. У США гірше - майже 66%.

Гаразд, припустимо, я переконав вас у тому, що мобільні програми були приречені, і тепер ви хочете дізнатись про нові прогресивні речі, щоб бути у вершині гри, коли веб-програми повністю завойовують мобільний світ. Головне, що слід зрозуміти, це те, що “Прогресивні веб-програми”Не є технологією, структурою чи мовою програмування. Це більше схоже на набір вимог, яким повинен відповідати ваш веб-додаток, щоб нормально функціонувати як прогресивний. Є кілька нових речей, які потрібно освоїти в процесі, але нічого складного.

Давайте подивимося, як саме PWA вдається функціонувати як власний мобільний додаток.

Оболонка програми це, ну, оболонка вашого додатка. Це мінімальний набір HTML, CSS та Javascript, необхідний для відображення головної сторінки вашої програми. Коли ви підключаєтесь до Інтернету та відкриваєте веб-сайт, ви чекаєте завантаження всієї головної сторінки, і це включає не лише динамічний вміст сторінки, але й усі зображення, шрифти, таблиці стилів, JavaScript, що використовуються на цій сторінці - і більшість вони залишаються незмінними незалежно від того, скільки разів ви відкривали сайт. То чому б не кешувати все це?

Коли PWA запускається вперше, він негайно поміщає всі статичні ресурси, які його оболонка програми вбудована в кеш. Наступного разу, коли додаток буде запущений, він буде обслуговувати всі статичні активи безпосередньо з кешу, що значно покращує час, перш ніж користувач побачить на екрані дорогоцінні пікселі. Якщо ви коли-небудь намагалися відкрити веб-сайт за допомогою 3G-з'єднання, ви зрозумієте, що я маю на увазі.

Це, мабуть, найпотужніше, на що здатні PWA. Вони можуть кешувати не тільки статичні компоненти оболонки програми, але й цілі відповіді від GET-запитів.

Скажімо, ви вчора відвідували веб-додаток для новин, щоб переглянути та прочитати деякі новини. Якщо ви відкриєте його сьогодні, ви миттєво отримаєте вчорашню стрічку новин на своєму екрані, поки програма отримує новий вміст у фоновому режимі, динамічно вбудовуючи його в канал, який ви вже переглядаєте. Якщо свіжий вміст не вдається отримати, наприклад, тому що ви перебуваєте в автономному режимі, ви залишатиметеся вчорашньою стрічкою, але принаймні ви не отримаєте жодних помилок або нескінченних обертів, які роблять весь додаток марним.

Існує кілька алгоритмів кешування, які ви можете застосувати, і від вас залежить, який саме вибрати, залежно від мети вашого додатка. Це основні з них:

  • Використовуйте “Кеш із резервним копіюванням до мережі”Якщо ви створюєте перший офлайн-додаток. Якщо відповідь уже є в кеш-пам’яті, вона буде подана користувачеві, і запит в Інтернеті ніколи не буде зроблений. Якщо відповідь ще не кешована, програма спробує отримати її в Інтернеті, а потім помістити в кеш. Цей підхід слід використовувати для вмісту, який змінюється дуже рідко або взагалі не змінюється.
  • “Мережа із резервним копіюванням у кеш”- це підхід, при якому користувачі Інтернету завжди отримують останню версію онлайнової версії, тоді як офлайн користувачі отримують кешовану версію. Використовуйте його для ресурсів, які часто оновлюються.
  • “Перегони кеш-пам’яті та мережі”- це коли ви одночасно шукаєте відповідь у кеші, одночасно запитуючи вміст у мережі. Спочатку ви показуєте кешовану відповідь користувача, а потім замінюєте її свіжим вмістом, коли він надходить, або додаєте новий вміст поверх кешованого, як це роблять Facebook і Twitter.

Незалежно від того, який шаблон ви використовуєте, ви завжди повинні вирішувати той випадок, коли відповідь ні кешована, ні отримати її в Інтернеті. У цьому випадку ви повинні подати статичну HTML-сторінку (яка також повинна бути кешована як частина оболонки програми), де буде сказано щось витончене, щоб заспокоїти користувача, наприклад «Вибачте, чувак, ваш кеш порожній, а Інтернет не працює - йди на нормальне життя ”. Це чудовий спосіб повідомити користувача, що щось пішло не так, і наразі немає можливості обслуговувати цей конкретний вміст. Це зробить вашу програму на 100% надійною та забезпечить її функціонування навіть під час апокаліпсису.

Підтримка в автономному режимі надзвичайно важлива, але для успішної заміни власного додатка ваш PWA також повинен виглядати та поводитися як один. Це досягається за допомогою файлу manifest.json, який містить відформатовані у форматі JSON властивості вашої програми, такі як ім'я, URL-адреса головної сторінки, піктограми для різної роздільної здатності пристрою, кольори початкового екрана, орієнтація пристрою, видно елементи керування браузера або не тощо.

Якщо ви відкриєте програму двічі на своєму мобільному пристрої (наразі лише Android), принаймні за 5 хвилин між відвідуваннями, вам буде запропоновано встановити її на пристрій (звичайно, якщо ваш маніфест на місці і відповідає необхідним критеріям, звичайно ). Якщо ви згодні з цим, ви побачите піктограму свого додатка на головному екрані вашого пристрою, мирно перебуваючи поруч із рідними програмами. Тепер ви можете запустити свій PWA так само, як і мобільний додаток - із приємним екраном із заставкою, розпізнаванням орієнтації, доступом до мобільного обладнання тощо. Звичайно, слід переконатися, що ваш PWA використовує дизайн, схожий на власний додаток, і особливо навігацію, я рекомендуємо використовувати одну з бібліотек компонентів інтерфейсу Material Design.

Ми дійшли до цього у статті, присвяченій Прогресивним веб-програмам, навіть не згадуючи працівника сервісу - Ого! Весь кеш, про який ми щойно говорили, виконується маленьким помічником браузера під назвою «Service Worker», який в основному є не чим іншим, як файлом JavaScript, що знаходиться у вашому додатку, але працює в окремому процесі, а це означає, що він не буде припинений коли ви закриваєте програму у своєму браузері (або навіть у самому браузері). Після реєстрації на головній сторінці програми Service Worker повинен негайно кешувати статичні активи оболонки програми і почати прослуховувати запити, надіслані програмою, кешувати та обслуговувати відповіді на основі логіки, яку ви запрограмували в ній.

Сервісний працівник не має доступу до DOM - тому навіть не намагайтесь це робити, - але він має доступ до всіх веб-API, і саме в цьому полягає його сила. На додаток до кешування, він може надсилати сповіщення, push-повідомлення, синхронізувати локальний кеш із віддаленим сховищем даних у фоновому режимі, він навіть може знущатись над відповідями з динамічно створеним вмістом, якщо ви запрограмуєте.

Сервісний працівник продовжуватиме жити у вашому веб-переглядачі, поки ви явно не вимкнете його з Консолі розробника веб-переглядача або не внесете до нього зміни, і в цьому випадку він оновиться до нової версії. Це дуже корисно, коли ваш додаток постійно оновлюється, і є основною перевагою порівняно з мобільними програмами, про які потрібно пам’ятати, щоб оновлювати.

Тож, чи все так ясно і мирно на небесах PWA? Не зовсім.

Перш за все, концепція порівняно нова, тому працівники служби та веб-маніфест ще не підтримуються усіма основними браузерами. Найбільшим вузьким місцем тут є відсутність підтримки з боку Apple, яка, очевидно, вважає зростання прогресивних веб-програм безпосередньою загрозою для AppStore. Хоча і Service Worker, і Маніфест веб-додатків підтримуються Chrome і Firefox протягом тривалого часу, Safari змінив статус реалізації Service Worker з «На розгляді» на «У розробці» лише в середині 2017 року та «Маніфест веб-програми» все ще знаходиться на "розгляді". Ого.

По-друге, навіть ті браузери, які вже прийняли SW, мають різний рівень підтримки, коли мова заходить про веб-API (як демонструє whatwebcando.today), тому ви повинні бути особливо обережними при розробці супер-крутої PWA, яка має доступ до Bluetooth або мікрофона., якщо вам потрібна підтримка між браузерами, звичайно.

До того ж, розробляти службовця не дуже просто (а налагодження - справжній кошмар). Ви повинні бути досить досвідченим розробником, щоб створити відносно складний Прогресивний веб-додаток. Життєвий цикл Service Workers трохи громіздкий, а сам сценарій заснований на обіцянках, тому переконайтеся, що ви використовуєте асинхронні API, щоб не блокувати виконання сторінки.

В Інтернеті є багато чудових і корисних прикладів, що було однією з причин, чому я намагався триматися подалі від фрагментів коду в цій статті. Ось лише декілька, які допоможуть вам розпочати свою дивовижну подорож у майбутнє Інтернету:

  • Фантастична стаття Джейка Арчібальда, що детально пояснює всі аспекти кешування керуючого службою, із фрагментами коду та прикладами.
  • Багатосекційна стаття від Google про саморобку для створення вашої першої PWA.
  • Приклади PWA з відкритим кодом від Google.
  • Розважальний вибір реальних прогресивних веб-програм, починаючи від простих конвертерів валют і закінчуючи складними магазинами електронної комерції та газетними агентствами.
  • Серія статей на тему PWA про WebAgility
  • Набори інструментів для початківців, які допоможуть вам створити програму з нуля. Деякі з них включають конструктор пакетів, веб-сервер або бібліотеку компонентів інтерфейсу. Деякі з них можуть навіть генерувати для вас код для працівника служби.

  • І останнє, але не менш важливе, надзвичайно корисне розширення Chrome під назвою Lighthouse, яке проводить аудит вашого додатка, щоб перевірити, наскільки він відповідає вимогам до прогресивного веб-додатку, і дає вам загальний бал, а також поради щодо того, як виправити речі, які ваш веб-додаток має низькі в.

Світанок планети веб-додатків настав перед нами, і ми щасливі жителі цієї планети, спостерігаючи злиття двох величезних світів - Інтернету та Мобільного. Результат, безумовно, буде не менш вражаючим: веб-розробники нарешті зможуть швидко створювати та розгортати програми, які однаково чудово виглядають і функціонують на всіх платформах, тоді як користувачі додатків отримають миттєвий доступ до своїх улюблених веб-ресурсів у вигляді мобільних додатків, але ефективніші, менші за розміром, миттєво відкриваються та завжди актуальні.

Вітаємо! Тепер ви повністю здатні вести чат, присвячений PWA, який, безсумнівно, зробить вас зіркою будь-якої коктейльної вечірки та найкращим магнітом для курчат, тож ідіть за ними!