简介

Web Notifications目前在w3c的协议中已经是“推荐”(REC:Recommendation)阶段,除了iE外,各大现代浏览器都对这个桌面推送有了基本的支持。这都代表我们现在可以很好的在应用中使用桌面推送的特性。在移动端浏览器方面,可能因为平台的权限限制的原因目前只有firefox积极地支持这个属性。Web Notifications也能很好的工作在web workers中。

常用API

  • Notification.permission

    使用 Web Notifications之前要向用户申请权限,Notification.permission属性是一个只读属性表示当前站点Web Notifications的状态,它有三个值defaultgranteddenied,在用户没有给予权限时,即站点的默认状态一般是default,仅在这个状态时,可以使用Notification.requireInteraction 向用户申请权限,用户会在浏览器上看到一个 Web Notifications权限的确认框,选择Notification.permission属性改变为granted表示用户允许使用Web Notifications,Notification.permission属性改变为denied表示用户禁止使用Web Notifications,并且不可再向用户申请权限。

    Safari (较旧版)和 Chrome (在 32 版本之前) 还没有实现 permission 属性。

  • Notification.requestPermission

    向用户申请权限函数,仅在Notification.permission状态为default时候生效。其他状态浏览器为了友好的用户体验不会再向用户请求权限,用户如果想要修改权限需要手动设置权限

    Notification.requestPermission有两种写法:

    • 对于比较新的浏览器,使用基于promise的语法

      1. Notification.requestPermission().then(function(permission) { ... });
    • 对于比较旧的浏览器,使用回调函数(Safari某些较新版本也需要使用回调函数)

      1. Notification.requestPermission(callback);
  • Notification 实例常用属性

    首先这里是一个简单的Notification实例:

    1. var notification = new Notification(title, {
    2. body: '...',
    3. icon: '...',
    4. sound :'...'
    5. });

    Notification.title 消息的主题

    Notification.icon 消息体的图标

    Notification.body 消息体的内容

    Notification.sound 消息体提示的声音(支持性很低)

  • Notification 实例相关事件

    1. Notification.onclick<br>
    2. Notification.onerror<br>
    3. Notification.onclose<br>
    4. Notification.onshow<br>
  • 一个demo的代码

  1. if (window.Notification) {
  2. var ua = navigator.userAgent.toLowerCase();
  3. if (ua.indexOf('safari') != -1) {
  4. if (ua.indexOf('chrome') > -1) {
  5. // Chrome
  6. Notification.requestPermission().then(function(permission) {
  7. if (permission == "granted") {
  8. var notification = new Notification('桌面推送', {
  9. body: '这是我的第一条桌面推送',
  10. icon: 'some/icon/url'
  11. });
  12. notification.onclick = function() {
  13. console.log('点击');
  14. notification.close();
  15. };
  16. } else {
  17. Notification.requestPermission();
  18. console.log('没有权限,用户拒绝:Notification');
  19. }
  20. });
  21. } else {
  22. // Safari
  23. Notification.requestPermission(function(permission) {
  24. if (permission == "granted") {
  25. var notification = new Notification('桌面推送', {
  26. body: '这是我的第一条桌面推送',
  27. icon: 'some/icon/url'
  28. });
  29. notification.onclick = function() {
  30. console.log('点击');
  31. notification.close();
  32. };
  33. } else {
  34. Notification.requestPermission();
  35. console.log('没有权限,用户拒绝:Notification');
  36. }
  37. })
  38. }
  39. }
  40. } else {
  41. console.log('不支持Notification');
  42. }

手动设置权限

chrome用户请在 "设置->隐私设置->内容设置->通知"选择网站域名点击允许

其他浏览器类似,请自己google

HTML5 Web Notifications 桌面推送小记的更多相关文章

  1. 基于Web的数据推送技术(转)

    基于Web的数据推送技术 对于实时性数据显示要求比较高的系统,比如竞价,股票行情,实时聊天等,我们的解决方案有以下几种.1. HTTP请求发送模式,一般可以基于ajax的请求,比如每3秒一次访问下服务 ...

  2. SSE(Server-sent events)技术在web端消息推送和实时聊天中的使用

    最近在公司闲着没事研究了几天,终于搞定了SSE从理论到实际应用,中间还是有一些坑的. 1.SSE简介 SSE(Server-sent events)翻译过来为:服务器发送事件.是基于http协议,和W ...

  3. NET Core2基于RabbitMQ对Web前端实现推送功能

    NET Core2基于RabbitMQ对Web前端实现推送功能 https://www.cnblogs.com/Andre/p/10012329.html 在我们很多的Web应用中会遇到需要从后端将指 ...

  4. 我有 7种 实现web实时消息推送的方案,7种!

    技术交流,公众号:程序员小富 大家好,我是小富- 我有一个朋友- 做了一个小破站,现在要实现一个站内信web消息推送的功能,对,就是下图这个小红点,一个很常用的功能. 不过他还没想好用什么方式做,这里 ...

  5. Web端服务器推送技术原理分析及dwr框架简单的使用

    1 背景 “服务器推送技术”(ServerPushing)是最近Web技术中最热门的一个流行术语.它是继“Ajax”之后又一个倍受追捧的Web技术.“服务器推送技术”最近的流行跟“Ajax ”有着密切 ...

  6. HTML5中的服务器‘推送’技术 -Server-Sent Events

    转帖:http://www.developersky.net/thread-63-1-1.html 一直以来,HTTP协议都是严格遵循Request-Response模型的.客户端发送一个Reques ...

  7. Web端server推送技术原理分析及dwr框架简单的使用

    1 背景 "server推送技术"(ServerPushing)是近期Web技术中最热门的一个流行术语.它是继"Ajax"之后又一个倍受追捧的Web技术.&qu ...

  8. [html5] 学习笔记-服务器推送事件

    1.HTML5服务器推送事件介绍 服务器推送事件(Server-sent Events)是Html5规范的一个组成部分,可以用来从服务端实时推送数据到浏览器端. 传统的服务器推送技术----WebSo ...

  9. 基于HTTP协议之WEB消息实时推送技术原理及实现

    很早就想写一些关于网页消息实时推送技术方面的文章,但是由于最近实在忙,没有时间去写文章.本文主要讲解基于 HTTP1.1 协议的 WEB 推送的技术原理及实现.本人曾经在工作的时候也有做过一些用到网页 ...

随机推荐

  1. Python中用字符串导入module

    在Python中,无法通过字符串来导入一个module文件: import "string" # Error x = "string" import x # 不 ...

  2. Scrum立会报告+燃尽图(Beta阶段第二周第七次)

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2415 项目地址:https://coding.net/u/wuyy694 ...

  3. 软件工程-东北师大站-第七次作业(PSP)

    1.本周PSP 2.本周进度条 3.本周累计进度图 代码累计折线图 博文字数累计折线图 4.本周PSP饼状图

  4. tensorboard入门

    Tensorboard tensorboard用以图形化展示我们的代码结构和图形化训练误差等,辅助优化程序 tensorboard实际上是tensorflow机器学习框架下的一个工具,需要先安装ten ...

  5. c++团队作业工作笔记

    这周时间还比较充裕,所以就有较多的时间来投入团队作业之中. emmmm,由于组长那边感觉完全没动,于是我完成了选英雄的UI界面,到时候给button加上信号就没什么问题. 虽然界面比较简单,但是还是花 ...

  6. 第二次c++作业

    用c语言实现电梯问题的方法: 先用一堆变量存储各种变量,在写一个函数模拟电梯上下移动载人放人的过程. c++: 构造一个电梯的类,用成员函数实现电梯运作的过程. 对c和c++的理解太浅,并没有感觉到用 ...

  7. 【IdentityServer4文档】- 启动和概览

    启动和概览 有两种基本的方式来启动一个新的 IdentityServer 项目: 从空项目开始(从头开始) 从 Visual Studio 的 ASP.NET Identity 模板开始 假如您从头开 ...

  8. 数据挖掘聚类算法(DBSCAN、Kmeans)Java实现

    学习聚类算法时,参考算法说明随手写的java实现,代码很简单,不多做说明啦,有需要的童鞋可以看看,自己也做个备录. http://files.cnblogs.com/files/yuananyun/% ...

  9. PHP中普通属性和静态属性

    普通属性(实例属性): 实例的单词为:instance 实例,其实也叫做“对象”: 普通(实例)属性,就是一个可以在该类实例化出的对象上使用的属性! 定义形式: class  类名{ var  $属性 ...

  10. js get selected text

    js get selected text https://stackoverflow.com/questions/3170648/how-to-get-javascript-select-boxs-s ...