--- title: PushManager slug: Web/API/PushManager tags: - API - Experimental - Interface - NeedsTranslation - Push - Push API - Reference - Service Workers - TopicStub translation_of: Web/API/PushManager ---
{{SeeCompatTable}}{{ApiRef("Push API")}}
Push API 的PushManager接口提供了从第三方服务器接收消息通知的能力。
可以通过ServiceWorkerRegistration.pushManager属性获得
注意: 这个属性替代了已被废弃的{{domxref("PushRegistrationManager")}}
None.
null。'granted','denied' ,'prompt'中的一种。PushPermissionStatus状态,该状态只能是'granted','denied' ,'default'中的一种。目前已经被{{domxref("PushManager.permissionState()")}}取代。this.onpush = function(event) {
console.log(event.data);
// 这里我们可以将数据写入IndexedDB,发送给其他window对象,或者显示一个通知
}
navigator.serviceWorker.register('serviceworker.js').then(
function(serviceWorkerRegistration) {
serviceWorkerRegistration.pushManager.subscribe().then(
function(pushSubscription) {
console.log(pushSubscription.subscriptionId);
console.log(pushSubscription.endpoint);
// 现在我们已经获取到了服务器需要的push订阅信息,我们可以使用XHR将它们发送给服务器
}, function(error) {
// 在开发环境下打印错误是很有帮助的。在生产环境下,将错误上报到服务器也是十分必要的
console.log(error);
}
);
});
| Specification | Status | Comment |
|---|---|---|
| {{SpecName('Push API','#pushmanager-interface','PushManager')}} | {{Spec2('Push API')}} | Initial definition. |
| Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari (WebKit) |
|---|---|---|---|---|---|
| Basic support | {{CompatChrome(42.0)}} | {{CompatGeckoDesktop(44.0)}}[1] | {{CompatNo}} | {{CompatUnknown}} | {{CompatNo}} |
| Feature | Android | Android Webview | Firefox Mobile (Gecko) | Firefox OS | IE Mobile | Opera Mobile | Safari Mobile | Chrome for Android |
|---|---|---|---|---|---|---|---|---|
| Basic support | {{CompatNo}} | {{CompatNo}} | {{CompatGeckoMobile(48)}}[2] | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} | {{CompatChrome(42.0)}} |