私 「ねぇ、Service Workerってあなた何者?」
Service Worker 「プログラム可能なネットワークプロキシです」
私 「.....(´Α`lll)o0(イミフ)」
(この記事は元々英語で投稿した記事の翻訳版です。挿絵に入っているテキストが英語のままなのはご了承ください🙏)
Service Workerってなんかカッコ良さそうだけど、実際問題なんなのかよくわからない
2015年7月、私はテキサス州オースティンで開催されたJavaScriptのカンファレンスに参加していた。ステージに立っていたのはJake Archibald、当時はなんかトイレの話ばっかりするおもしろイギリス人くらいにしか思ってなかったけれど、後々Service Workerのスペック策定に関わっているちょっとすごい人だと知る。
(なぜか)公衆トイレで発見したUXパターンについて話す傍ら、JakeはService Workerとかいうウェブサイトをアプリっぽくしてくれる(当時の私の理解では)、新しい技術について熱烈に語っていた。
なんとなく面白そう!プロジェクトで使えたらカッコ良さそう!と思ったものの、最初に取り掛かるまでがちょっと大変だった。Service Workerは新しいHTMLタグでもなければ、JavaScriptの新しいシンタックスでもない...「初めてのService Worker」的な記事を読んでみても、プロキシとかキャッシュとか(普段フロントエンドを担当していて)慣れない単語が出てきて混乱する。しょうがないので記事を読みながら、Service Workerはブラウザ内で呼び出せるエイリアンだ!と絵にしてみたらようやく理解できた。(意味不明?まぁちょっと話を聞いてください。)
ブラウザ世界におけるエイリアン、Service Worker
ウェブブラウザをコンピューター銀河における一つの惑星(例えば地球)だと例えてみる。このブラウザ星に住む人々はHTML, CSS, JavaScriptといった言語を使って社会を構築している。もし貴方がウェブ系エンジニアなら、この惑星にどんな原子(DOMエレメント)が存在するかとか、ごみの収集日(ガベージコレクション)とかを知っているだろう。
この惑星はHyper Text Transfer Protocolという、通信手段を持っていて、例えばほかの銀河(サーバー)から資源を調達するのに使われる。このHTTPによってブラウザ星は自身をアニメGifやらツイートやらで埋め尽くすことが出来る。これがブラウザ星の最もユニークな特徴であり、多くの人を引きつける所以である。
HTTPというと魔法のように聞こえるけれど、実際にはインターネットと呼ばれる水道管を通してでないと、ほかの銀河とはHTTP通信できない。
この水道管の太さや長さは、どれくらい配管工(インターネットサービス・プロバイダ)にお金を払ったかとか、あなたの地域にどんなインフラが敷かれているかとかによって異なる。この水道管が細くて長いほど、他の銀河からの資源調達に時間がかかる。
困ったことにこのインターネット水道管は常に存在するとは限らない。この水道管を見つけられなかったとき、ブラウザ星は(技術の存在しなかった)大昔をしのんで恐竜を引っ張り出してくる。
でもちょっとまって!助っ人Service Workerの登場!
Service Worker はブラウザ星とインターネット水道管の間に立ってくれる助っ人のようなもの。Service Workerに通信したい内容を伝えると、サーバー銀河への通信を取り持ってくれる。なんとなくUFOに乗ったエイリアンっぽい感じがする。
Service Workerについて知るべき3つの事柄
Service Workerは「呼び出す」もの。呼び出さない限りあなたのブラウザにService Workerは存在しない。でも一旦呼び出したら、頼んだ仕事が終わるまでは帰ってくれない。Web Workerと違って、
terminate()
といった強制終了メソッドは無い。Service Workerはウェブサイトの外に住んでいる。通常ブラウザウィンドウを閉じるとなにも使えなくなってしまう(ビデオダウンロードもできないし、ネット小説を読むことも出来ない)。奇跡のような話だけれど、Service Workerはブラウザウィンドウが閉じた状態でも、必要とされた場合は「起きている」ことができる。ただし、ウェブページ製作者はService Workerがいつ起きているかといったライフサイクルのコントロールはできない。(だからちょっとエイリアンっぽいと私は思っている。)
前述したとおりService Workerはウェブサイトの外に住んでいるので、ブラウザ星内部に触ることが出来ない。 Service Wroker からは
window
もdocument
アクセスできないし、DOMをいじることも出来ない。
じゃぁService Workerはどんなことが出来るの?
1. キャッシュをいじる
Service Workerはfetch
イベントの仲介人の役割をしてくれる。
Service Workerに特定のファイルをキャッシュするよう頼んだり、キャッシュされたファイルが存在する場合は外部へHTTPリクエストを送る前にキャッシュを返すように頼むことが出来る。キャッシュが存在する限り、インターネットに接続していなくてもブラウザはページを表示出来る。
2. プッシュ通知送信
「Service Workerはブラウザウィンドウが閉じていても起きている」のでプッシュ通知送信といったことが出来るようになる。
3. バックグランド同期
「ブラウザウィンドウが閉じていても起きている」ということはつまり、ユーザーが見ていないところで働いてくれたりもする。
例えばユーザーがブラウザオフライン状態のときに、ファイルアップロードを行ったとしよう。Service Workerはデバイスがオンラインになった時点で、バックグラウンドで(ユーザーが気づかないうちに)ファイルアップロードをしてくれる。
Service Workerってちょっとワケがわからないと思っていた人が、この記事を読んでちょっとでも解った!と思ってくれたらうれしいです。さっそくコードを書いてみたくなったなら、Jake Archibaldのoffline-cookbookをオススメします。
この記事は クリエイティブコモンズBY-NC-SA 4.0 ライセンスで公開しています。