Web Notifcation介绍
创始人
2024-05-23 18:59:30
0

查看原文
简单的说Web Notifcation就是在浏览器中调用操作系统自身的通知,当浏览器窗口缩小,或者切换到其他页面后仍然可以提示用户。

一、传统的提示

以常见的web在线聊天为例,通常在收到新消息后定时修改document.title 以闪烁的方式来通知用户,同时使用音频播放声音(Chrome必须要与界面有交互后才能播放声音);或者在浏览器右上角弹出notifaction通知来通知用户。这些方式在浏览器缩小后都不能达到很好的效果。以前的文章js实现页面title闪烁。

二、Web Notifcation

需要注意的是,该功能需要在https环境下才能使用,本地演示不了;同时需要用户同意之后才会生效,在Web Worker中也能使用了。

Notification.permission 介绍

该属性标明用户是否接受现实通知,可能的值如下:

  • denied: 用户拒绝显示通知
  • granted: 用户接受显示通知
  • default:用户选择是未知的,因此浏览器的行为类似于值是 denied

Notification.requestPermission()

上面的 Notification.permission 的值表示是否接受通知,Notification.requestPermission就是请求获取用户的通知权限。

官方示例代码,删除了注释:


function notifyMe() {if (!("Notification" in window)) {// Check if the browser supports notificationsalert("This browser does not support desktop notification");} else if (Notification.permission === "granted") {const notification = new Notification("Hi there!");} else if (Notification.permission !== "denied") {Notification.requestPermission().then((permission) => {if (permission === "granted") {const notification = new Notification("Hi there!");}});}
}

Notification.close()

手动的方式关闭通知,一般系统会在一段时间之后自动关闭通知。

事件

  • click : 当用户点击通知时触发。
  • close : 当用户关闭通知时触发。
  • error : 当通知发生错误时触发。
  • show : 当通知显示时触发。

构造函数

let myNotification = new Notification(title, options);
  • title : 通知的标题,显示在通知的顶部
  • options :可选项
    • dir : 通知显示的方式,通常跟随浏览器的语言方向,可以设置为ltr和rtl(看起来与css的direction类似)。
    • lang :通知的语言
    • badge : 一个用于表示通知的图像的URL,当没有足够的空间用于显示通知本身时。
    • body : 通知的正文,显示在标题下方。
    • tag : 通知的识别标签。
    • icon : 要在通知中显示的图标的 URL
    • image : 要在通知中显示的图像的 URL
    • data :您想要与通知相关联的任意数据。这可以是任何数据类型。
    • vibrate : 振动模式,通知时设备的振动设置。
    • renotify : 新通知替换旧通知后是否应通知用户,默认false
    • requireInteraction : 通知应保持有效,直到用户点击或关闭它,而不是自动关闭,默认false

兼容性

除了IE主流的浏览器基本都支持
在这里插入图片描述

参考文章

MDN Notification

相关内容

热门资讯

安卓系统的经典铃声,唤醒回忆的... 你有没有发现,手机里那些熟悉的铃声,有时候就像老朋友一样,陪伴着我们度过了无数个日日夜夜?今天,就让...
鸿蒙系统还是安卓系统号,系统之... 你有没有想过,手机里的操作系统就像是我们的大脑,它决定了我们手机能做什么,不能做什么。现在,就让我们...
安卓系统装贝达,安卓系统下的贝... 你有没有想过,你的安卓手机装上贝达系统后,会有怎样的奇妙体验呢?想象你的手机瞬间变身,变得流畅无比,...
安卓系统沃尔沃音响设置,轻松享... 你有没有发现,自从你的安卓手机和沃尔沃音响完美结合后,开车时的音乐体验简直就像是在音乐厅里一样?没错...
米10系统基于安卓,基于安卓的... 你知道吗?最近手机圈里可是热闹非凡呢!小米10这款手机,自从发布以来就吸引了无数人的目光。而它所搭载...
命令安卓系统怎么卸载,安卓系统... 手机里装了太多不用的应用,是不是感觉手机都快要爆炸了?别急,今天就来教你怎么轻松卸载安卓系统中的应用...
安卓系统安装小学教材,安卓系统... 你有没有想过,手机里的安卓系统竟然能装上小学教材呢?没错,你没听错!在这个信息爆炸的时代,科技的发展...
华为安卓系统锁住了,揭秘锁屏背... 最近是不是发现你的华为手机有点儿“顽皮”了?它突然间变得神秘起来,屏幕上那个熟悉的安卓系统仿佛被施了...
安卓电脑改苹果系统,跨越平台的... 你有没有想过,把你的安卓电脑改头换面,变成一个优雅的苹果系统使用者呢?想象那流畅的界面,那独特的触控...
安卓系统怎么按后台,并在任务完... 你有没有遇到过这种情况:手机屏幕一黑,安卓系统就自动进入后台了?是不是觉得有点小郁闷,想要手动切换回...
2021年安卓系统ui,202... 你有没有发现,手机界面最近好像换了个模样?没错,2021年的安卓系统UI可是来了一场大变身呢!今天,...
安卓系统程序编写软件,打造个性... 你有没有想过,手机里的那些神奇应用是怎么诞生的呢?没错,就是那些让你在闲暇时光刷刷视频、在通勤路上玩...
自动开机安卓系统,智能生活新篇... 你有没有想过,当你的安卓手机在清晨的第一缕阳光照耀下自动开机,那种轻松自在的感觉?想象不用再手动解锁...
真我平板x安卓系统,畅享智能生... 亲爱的读者们,你是否也在寻找一款既能满足你对平板电脑的期待,又能让你畅享安卓系统带来的无限乐趣的设备...
恒星安卓系统官网,引领未来智能... 亲爱的读者们,你是否曾好奇过那些闪耀在夜空中的星星,它们是如何在浩瀚的宇宙中熠熠生辉的呢?今天,我要...
u8安卓系统,功能与特色深度解... 你知道吗?在手机操作系统界,有一个小家伙可是相当受欢迎的,它就是U8安卓系统。今天,就让我带你来一探...
花椒安卓系统美颜功能,打造完美... 你有没有发现,现在拍照已经不仅仅是记录生活的工具了,它更是一种艺术创作呢!而在这其中,花椒安卓系统的...
戴尔平板升级安卓系统,畅享安卓... 你有没有发现,戴尔平板最近好像悄悄地来了一次大变身?没错,就是那个我们熟悉的戴尔平板,它现在竟然可以...
安卓助手怎么升级系统,畅享最新... 亲爱的安卓用户们,你是否也和我一样,对安卓系统的升级充满了期待和好奇呢?每次系统升级,都仿佛是给我们...
国产安卓系统的发展,国产安卓系... 你知道吗?在我国科技飞速发展的今天,国产安卓系统可是越来越受到大家的关注呢!它就像一颗冉冉升起的新星...