Badging API
The Badging API gives web developers a method of setting a badge on a document or application, to act as a notification that state has changed without displaying a more distracting notification. A common use case for this would be an application with a messaging feature displaying a badge on the app icon to show that new messages have arrived.
Concepts and Usage
Web developers frequently update document favicons or titles in order to indicate status. The Badging API provides a more elegant way to show status, by providing a method which has meaning to the user agent and can therefore be displayed in a way that matches the rest of the UI.
Types of badges
There are two types of badges:
- Document badges, which are typically shown in the browser tab near or on the page icon.
- App badges, which are associated with the icon of an installed web app. These may display on the app icon in the dock, shelf, or home screen depending on the device in use.
Badge states
A badge can have one of three possible values, which are set internally:
nothing
-
Indicating that no badge is currently set. A badge can be in this state due to it being cleared by the application, or being reset by the user agent.
flag
-
Indicating that the badge is set, but has no specific data to display. A badge will be in this state if the application has set a badge, but has not passed any value to the method.
an integer
-
A value passed when setting the badge. This value will never be
0
, passing a value of0
when setting a badge will cause the user agent to clear the badge by setting it tonothing
.
Setting badges
A badge is set with the methods setAppBadge()
(for installed apps), or setClientBadge()
(for documents). If no parameters are passed to these methods then the badge value is flag. The user agent will display its notification badge, for example, a colored circle on the icon.
These methods can also be passed a parameter contents
, which should be a number. This will then be displayed as part of the badge. User agents may change this value in some way. For example, if you pass a very large number such as 4000, the user agent may display this as 99+ in the badge. User agents may also ignore this data and display a marker instead.
Clearing badges
Badges are cleared with the clearAppBadge()
and clearClientBadge()
methods. These do not take any parameters and set the badge to the value nothing
. Additionally, passing a value of 0
to setAppBadge()
or setClientBadge()
will set the badge to nothing
and clear the badge.
Interfaces
None.
Extensions to the Navigator interface
-
Sets a badge on the icon associated with this app.
-
Clears the badge on the icon associated with this app.
-
Sets a badge on the icon associated with the current document.
-
Clears the badge on the icon associated with the current document.
Extensions to the WorkerNavigator interface
-
Sets a badge on the icon associated with this app.
-
Clears the badge on the icon associated with this app.
-
Sets a badge on the icon associated with the current document.
-
Clears the badge on the icon associated with the current document.
Examples
To set a notification badge on the current document with no value:
js
navigator.setClientBadge();
To clear a notification badge on the current document:
js
navigator.clearClientBadge();
To set a notification badge on the current app with a value of 12:
js
navigator.setAppBadge(12);
Specifications
Specification |
---|
Badging API # setappbadge-method |
Browser compatibility
BCD tables only load in the browser