この記事は編集レビューを必要としています。ぜひご協力ください。
これは実験段階の機能です。
この機能は複数のブラウザで開発中の状態にあります。各ブラウザで用いるために、適切なベンダー接頭辞が必要な場合があります。互換性テーブルをチェックしてください。また、実験段階の機能の構文と挙動は、仕様変更に伴い各ブラウザの将来のバージョンで変更になる可能性があることに注意してください。
ServiceWorkerRegistration
インターフェースの pushManager
プロパティは、プッシュサブスクリプションを管理するための PushManager
インターフェースへの参照を返します; これは、サブスクライブと有効なサブスクリプションの取得、プッシュ許可状況へのアクセスのサポートを含みます。
構文
myPushManager = ServiceWorker.pushManager
値
PushManager
オブジェクト。
例
this.onpush = function(event) { console.log(event.data); // ここから、IndexedDB にデータを書き込んだり、いずれかのウィンドウに // それを送信したり、通知を表示したりできます。 } navigator.serviceWorker.register('serviceworker.js').then( function(serviceWorkerRegistration) { serviceWorkerRegistration.pushManager.subscribe().then( function(pushSubscription) { console.log(pushSubscription.subscriptionId); console.log(pushSubscription.endpoint); // アプリケーションサーバが必要としているプッシュサブスクリプションの // 詳細はここから使用できます。たとえば、XMLHttpRequest を使用して // これを送信できます。 }, function(error) { // 開発中は、コンソールにエラーを表示するのに役立ちます。 // 本番環境では、アプリケーションサーバにエラー情報を送信 // するためにも 役立ちます。 console.log(error); } ); });
仕様
仕様 | 状態 | コメント |
---|---|---|
Push API PushManager の定義 |
草案 | 初期定義。 |
ブラウザ実装状況
機能 | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari (WebKit) |
---|---|---|---|---|---|
基本サポート | 42.0 | 44.0 (44.0)[1] | 未サポート | ? | 未サポート |
機能 | Android | Android Webview | Firefox Mobile (Gecko) | Firefox OS | IE Mobile | Opera Mobile | Safari Mobile | Chrome for Android |
---|---|---|---|---|---|---|---|---|
基本サポート | 未サポート | 未サポート | 未サポート | 未サポート | 未サポート | 未サポート | 未サポート | 42.0 |
[1] Push(と Service Workers) は、Firefox 45 延長サポート版(ESR)では使用できません。