--- title: PWAをもっと簡単に初めてみる tags: PWA Vue.js JavaScript HTML5 iOS author: poster-keisuke slide: false --- # はじめに PWAって知っていますか?(自分は最近知りました👱) では、実際に使ったことがある、あるいは触ってみたことがある方はどのくらいいらっしゃるでしょうか。 色々なPWAの初学者用の記事を見たのですが、どれも丁寧に書かれていてとりあえず使ってみたい私にとっては難しいとかんじてしましまいました…😵 そんな自分のような方向けに、もっと簡単にPWAを初めてみようという主旨で書きました! 今回は、自分が最近触っているvue.jsを利用して組み合わせてみました。 ## PWAとは そもそもPWAとはなんでしょうか? > PWA(Progressive Web Apps)はグーグルがモバイルユーザーのユーザー体験向上を目的とし、今までのWebアプリ(サービス)にWebとアプリの両方の利点を兼ね備えた仕組みのことです。 [Googleが取り組むWebのアプリ化プロジェクト「PWA」とは?- WPJ](https://www.webprofessional.jp/what-is-the-attention-project-pwa-by-google/) この記事に詳しく書かれているので、詳細は省きますが、簡単に言うと**WEBページをネイティブアプリのような**ユーザー体験を提供する仕組みと、理解して頂ければいいかと思います。 上の記事でも紹介されていますが、PWAの最大の特徴は(自分が衝撃を受けたのが)、 *オフラインでも動作する*ということです。(service workerという仕組みのおかげです。) それ以外にも、アプリの様に動作するが、アプリの審査が不必要であったり、プッシュ通知機能が使えるようになるなどの利点があります。 ## 簡単に解説 サンプルは以下のページにあります。(vueのチュートリアルを利用しています。) https://poster-keisuke.github.io/ 手順は以下の通りです。 1. 必要なファイルの紹介 2. エントリポイントの作成 3. ファイルのアップロード ### 1. 必要なファイルの紹介 今回、利用するファイルは以下のとおりです。 #### index.html エントリポイント用。アプリの表示部分 #### service_worker.js ServiceWorkerの処理を書くファイルになります。 今回はキャッシュファイルのインストールとロードの部分が書いてあります。 (ファイルがキャッシュされている場合、オフラインでも動作が可能になります。) `service_worker.js`では、主に、**キャッシュファイルの設定**と、**インストール処理**と**キャッシュロード処理**を記述しています。 `var urlsToCache`で登録したurlをキャッシュしてくれるので、それらのファイルをオフラインでも利用可能にできます。 例えば、外部下した`js`ファイルや、`css`ファイル等もこちらに登録しておくことができます。 ```service_worker.js // キャッシュファイルの指定 var CACHE_NAME = 'pwa-sample-caches'; var urlsToCache = [ '/poster-keisuke.github.io/', ]; // インストール処理 self.addEventListener('install', function(event) { event.waitUntil( caches .open(CACHE_NAME) .then(function(cache) { return cache.addAll(urlsToCache); }) ); }); // リソースフェッチ時のキャッシュロード処理 self.addEventListener('fetch', function(event) { event.respondWith( caches .match(event.request) .then(function(response) { return response ? response : fetch(event.request); }) ); }); ``` #### manifest.json PWAとしての設定情報を記述しておきます。 `name`と`start_url`は登録必須になります。今回`start_url`は`index.html`ですが、 start_url プロパティを変更してエントリポイントを index.html 以外にすることも可能です。 ``` manifest.json { "short_name": "PWA", "name": "PWA sample app", "display": "standalone", "start_url": "index.html", "icons": [ { "src": "images/icon.jpg", "sizes": "192x192", "type": "image/jpg" } ] } ``` その他のオプションが気になる方は、以下を確認して見てください。 [ウェブアプリ マニフェスト  |  Web  |  Google Developers](https://developers.google.com/web/fundamentals/web-app-manifest) ### 2.エントリポイントの作成 まずは、エントリポイント(最初に読み込まれるページ)を作成します。 今回はこのページで必要なjs等を読み込んであげます。 ```index.html    PWA Sample

{{ message }}

``` ここでは、service workerの登録と、vue.jsの読み込みを行っております。 ## 3.ファイルのアップロード 最後にファイルをサーバーにアップロードして終了です。 PWAは`https`でないと動作しないので、サーバー選びは大切になってきますが、より簡単に利用するにはGitHubページがおすすめです(最近httpsに対応したようです。) ページの作り方は以下の記事を参考にしてみて下さい。 [GitHubを使って3分でHPを公開する。 - Qiita](https://qiita.com/budougumi0617/items/221bb946d1c90d6769e9) そしてアップロードして、ページを開くと、 https://poster-keisuke.github.io/ ![test.gif](https://qiita-image-store.s3.amazonaws.com/0/140786/5c091735-b9f9-811b-3059-9fd090242e70.gif) (PCで開くとただの、vueサンプルです笑) PWAの効力は、スマートフォンのホーム画面に保存して発揮します。 以下のように、webページをホーム画面に保存して下さい。(最近iPhoneのiOS11.3からPWAに対応したので、iPhoneでも利用できます:clap:) ![Image uploaded from iOS (1).png](https://qiita-image-store.s3.amazonaws.com/0/140786/93bba395-18b0-62b9-6fff-98b20fe2b440.png) その状態でページを開くと、以下の様にアプリ画面の様に全画面表示で表示されるのが分かるかと思います。 このページが開けるのであれば、オフラインでも開くとことができるので、試しにオフラインにして試して見て下さい。 (iPhoneであれば機内モードを利用することで、オフラインにすることができます。) ![Image uploaded from iOS.png](https://qiita-image-store.s3.amazonaws.com/0/140786/574aab37-d41d-d37c-46ae-06248e829d8b.png) ## おわりに いかがでしたでしょうか。 こうして手を動かしてみると、こんなに簡単な手順でPWAを実現することができるのがわかったかと思います。 ぜひ、一度試してみてください。 次回以降は、WebサービスをPWA適応できるような記事を書こうかと思います。 #### 参考 - [Googleが取り組むWebのアプリ化プロジェクト「PWA」とは?- WPJ](https://www.webprofessional.jp/what-is-the-attention-project-pwa-by-google/) - [はじめてのプログレッシブ ウェブアプリ  |  Web  |  Google Developers](https://developers.google.com/web/fundamentals/codelabs/your-first-pwapp/) - [いまさら聞けないPWAとAMP - Qiita](https://qiita.com/edwardkenfox/items/4c0b9550ffa48c1f0445) - [PWA 入門 〜iOS SafariでPWAを体験するまで〜 2018年3月版 - Qiita](https://qiita.com/umamichi/items/0e2b4b1c578e7335ba20)