这是
实验性技术
检查
浏览器兼容性表格
要小心谨慎在生产中使用这之前。
PushManager.getSubscription()
方法在
PushManager
interface retrieves an existing push subscription.
It returns a
Promise
解析为
PushSubscription
object containing details of an existing subscription. If no existing subscription exists, this resolves to a
null
值。
PushManager.getSubscription().then(function(pushSubscription) { ... } );
None.
A
Promise
解析为
PushSubscription
object or
null
.
This code snippet is taken from a push messaging and notification sample . (No live demo is available.)
// We need the service worker registration to check for a subscription
navigator.serviceWorker.ready.then(function(serviceWorkerRegistration) {
// Do we already have a push message subscription?
serviceWorkerRegistration.pushManager.getSubscription()
.then(function(subscription) {
// Enable any UI which subscribes / unsubscribes from
// push messages.
var pushButton = document.querySelector('.js-push-button');
pushButton.disabled = false;
if (!subscription) {
// We aren’t subscribed to push, so set UI
// to allow the user to enable push
return;
}
// Keep your server in sync with the latest subscriptionId
sendSubscriptionToServer(subscription);
showCurlCommand(subscription);
// Set your UI to show they have subscribed for
// push messages
pushButton.textContent = 'Disable Push Messages';
isPushEnabled = true;
})
.catch(function(err) {
window.Demo.debug.log('Error during getSubscription()', err);
});
});
| 规范 | 状态 | 注释 |
|---|---|---|
|
Push API
The definition of 'getSubscription()' in that specification. |
工作草案 | 初始定义。 |
| 桌面 | 移动 | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
getSubscription
|
Chrome 42 |
Edge
16
Disabled
|
Firefox
44
|
IE 不支持 No | Opera 29 | Safari 不支持 No | WebView Android 不支持 No | Chrome Android 42 |
Firefox Android
48
|
Opera Android 29 | Safari iOS 不支持 No | Samsung Internet Android 4.0 |
完整支持
不支持
实验。期望将来行为有所改变。
见实现注意事项。
用户必须明确启用此特征。
PushManager
getSubscription()
hasPermission()
permissionState()
register()
registrations()
subscribe()
unregister()