Desktop notifications enable the browser to notify users of even minimal state messages.

This kind of notice, users can choose whether to accept the notice of the website, and the overall UI style is unified, I think it is very suitable for information and video websites.

I have to say, the browser ecosystem is getting better and better, which is good for the front end. Most popular browsers on the PC side support this feature, but it is a pity that there is almost no support for this feature on the mobile side.

Let’s get started!

Judge authority

Check whether you have permissions before invoking the call, and ensure compatibility with unsupported browsers.

// Handle try{for browsers that do not provide an interfaceif(Notification.permission === 'granted'){// Authorized}else if(Notification.permission === 'denied'){// reject}else}} Catch (e){// This browser does not support}Copy the code

Request permission to

The za is not rascal software, always can disturb the user, get the user to agree to just go is not. Don’t worry, you only need to obtain permission once to use the same domain name forever.

// Grant grant; // Grant grant; // Grant grant; Denied refused Notification. RequestPermission (). Then (function(permission) {
    if(permission === 'granted'){
        console.log('User allowed notification');
    }else if(permission === 'denied'){
        console.log('User Reject notification');
    }
    init();
});Copy the code

Send a notification

If user authorization permits, we can invoke the notification method.

Remember to disable requireInteraction if it is set to true!

var n = new Notification('Notice is coming.',{
    body: 'This is an announcement.'// Add a tag to the notification:'a'// The contents of the same tag will display only one window icon at a time:'iconUrl', // The notification icon requireInteraction:true// Notifications remain valid and do not automatically close, default isfalse
})
setTimeout(function() {// requireInteraction requires you to configure shutdown notification. Close (); }, 10000);Copy the code

Put the above together and you have a simple example:

var n = new Notification('Notice is coming.',{
    body: 'Look, you're ready to receive notifications, click to go to my blog! ',
    tag: 'a',
    icon: 'http://secure.gravatar.com/avatar/14c889100dc44646b7da2344e2a2a375?s=32&d=mm&r=g',
    requireInteraction: true
})
setTimeout(function() {
    n.close();
}, 10000);Copy the code

The effect is as follows:



Click the implementation of the jump URL

Attentive friends may have noticed that I wrote in the notice that click can enter my blog yo.

Don’t worry, we’ll make it happen!

// If the user clicks on the notification, jump to the page for him and close the notification windowfunction(){
    window.open("http://blog.mokevip.top".'_blank'); // new window opens url n.close(); // And turn off notifications}Copy the code

conclusion

The general process is as follows:



Example: www.mokevip.top/message.htm…

Official documentation: developer.mozilla.org/zh-CN/docs/…

The demo code:

<! doctype html> <html> <head> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"> <title> JS browser notification example </title> </head> <body> <h1 id="msg"> You will receive a notification </h1> <script> init(); // Obtain the user notification permissionfunction getPower() {/ / get Notification access method, the result through the promise to return to the Notification. The requestPermission (). Then (function(permission) {
        if(permission === 'granted'){
            console.log('User allowed notification');
        }else if(permission === 'denied'){
	    console.log('User Reject notification'); } init(); }); } // Initialize to determine user permissionsfunction init(){// Handle try{for browsers that do not provide interfacesif(Notification.permission === 'granted'){
	    document.getElementById("msg").innerHTML="You will receive a notification."Var n = new Notification('Notice is coming.',{
	        body: 'Look, you're ready to receive notifications, click to go to my blog! '// Add a tag to the notification:'a'// The contents of the same tag will display only one window icon at a time:'http://secure.gravatar.com/avatar/14c889100dc44646b7da2344e2a2a375?s=32&d=mm&r=g', // The notification icon requireInteraction:true// Notifications remain valid and do not automatically close, default isfalse}) // Turn off notifications after 10 secondssetTimeout(function() { n.close(); }, 10000); // If the user clicks on the notification, jump to the page for him and close the notification windowfunction(){
	        window.open("http://blog.mokevip.top".'_blank'); // open the url n.close(); // And turn off notifications}}else if(Notification.permission === 'denied'){
	    document.getElementById("msg").innerHTML="You have declined notification permission."
	}else{
	    document.getElementById("msg").innerHTML="Agree permissions and you can receive notifications!"
	    getPower()
	}
    }
    catch(e){
	document.getElementById("msg").innerHTML="This browser does not support notification messages"
    }
}
</script>
</body>
</html>Copy the code

The article is here, if you like, welcome message support!

My blog address is: blog.mokeVIp. top/ will update some light technical content from time to time, blog white novice start, hope you support ha.