angular6はServiceWorkerとのバックグラウンド同期をサポートしていないようです。 angularサービスでライブラリなしでこれを行うために必要な手順は何ですか?
https://developers.google.com/web/updates/2015/12/background-sync
angular6アプリケーションのWorkerGlobalScopeに直接アクセスする方法と場所バックグラウンド同期を実行できます。:
self.addEventListener('sync', function(event) {
if (event.tag == 'myFirstSync') {
event.waitUntil(doSomeStuff());
}
});
問題は、angular CLIがservicworkerファイル(ngsw-worker.js)を生成することです。方法はありますか? toinject/modify/ extendこのファイル?はい、ファイルngsw-worker.jsを手動または別の凝ったトリックで編集できます。これを行う公式の方法はありますか?
はい、カスタムスクリプトを使用して、Angularのサービスワーカーの機能を拡張できます。
以下の手順に従ってください。
sw-custom.js
_としましょう。カスタムスクリプトを使用してjsファイルを作成します。sw-custom.js
_ファイルの先頭に「importScripts('./ngsw-worker.js')
」を追加します。sw-custom.js
_ファイルに_angular.json
_ファイルを追加します。sw-custom.js
_ファイルをappモジュールではなくappモジュールに登録しますngsw-worker.js
これで、必要に応じてここにスクリプトを記述できます。
多分それは正しいアプローチではありませんが、それは機能します。
これが ブログ です。