首页 > 作文

Html5中的桌面通知Notification的实现

更新时间:2023-04-03 08:46:28 阅读: 评论:0

前言:对于一个前段开发者,逛网页总会留意一些新奇的功能,对于上班总会用到teambition的我,总是能收到notification…所以今天就来研究下这个h5功能…

1. 实例一个notification

let n = new notification(  "这是一个通知消息", //这是必选title 一定会显示的通知标题  {    icon: "xxx.png", // 这个icon是用来显示通知中的左边图片    body: "你好啊,我是xxx",   // 通知中的内容字符    dir: auto,             // 文字的方向 值包含: auto(自动), ltr(从左到右), rtl(从右向左)    tag: "gxllf"          // 给与这个通知消息一个id, 用来对这个通知消息进行 刷新.移除.替换 等操作    // long: "en-us"               //lang字段 需要参考/d/file/titlepic/bcp47 并不是必须 没看出啥作用...    // ...            // 其余可选属性见下实例属性  })

访问对应的实例属性:
n.actions // 一个只读的notificationaction对象数组。每一个对象描述用户可以在一个通知中选择的单个操作。
n.image // 通知的一部分显示的图像的url
n.badge // 当没有足够的空间显示通知本身时,用于表示通知的图像的url。
n.permission // 有三个值 granted, denied, 或default 当状态值为granted时可以发送通知消息 default默认用户没处理 denied 用户拒绝
n.renotify // 布尔值。新通知出现的时候是否替换之前的。如果设为true,则表示替换,表示当前标记的通知只会出现一个。注意这里的“当前标记”没?没错,true参数要想起作用,tag必须需要设置属性值。
n.requireinteraction // 布尔值, 指的是通知是否保持活动直到用户点击或取消通知 而不是自动关闭..
n.silent // 布尔值。通知出现的时候,是否要有声音。默认fal, 表示无声。
n.timestamp //通知创建或者可以使用的时间。
n.data // 任意类型和通知相关联的数据。
n.vibrate // 通知显示时候,设备震动硬件需要的震动模式。所谓振动模式,指的是一个描述交替时间的数组,分别表示振动和不振动的毫秒数,一直交替下去。例如[200, 100, 200]表示设备振动200毫秒,然后停止100毫秒,再振动200毫秒。 (移动端)
n.sound // 字符串。音频地址。表示通知出现要播放的声音资源。
n.sticky // 通知吸附不容易被清除… (移动端)
n.noscreen // 布尔值。是否不再屏幕上显示通知信息。默认fal, 表示要在屏幕上显示通知内容。(移动端)

此时实例 n 有四个事件处理:
1> onclick 用户对通知信息的点击事件
2> onshow 通知消息展示之后触发的事件
3> onerror 遇到错误会触发的事件
4> onclo clo事件的处理

2. notification对象会有什么属性/方法呢?利用控制台中的window对象输出点开查看就可以看到:

值得注意的是: requestpermission()方法仅在notification对象有效,实例对象无效!!!这个方法是用来向用户申请显示通知的权限,只能被用户主动去调用(在页面onload中可以调用,可以向用户申请,之后再去发送…)

实例对象拥有的方法有:

    (1). clo() 用于关闭通知消息 –> 也可以在onshow方法加延迟调用,提高用户体验感…

    (2). addeventlistener() 监听事件(这个通用方法)

    (3). removeeventlistener 卸载监听事件(通用,同上)

    (4). dispatchevent 分派事件(同上)

接下来,写一个js测试, 如果使用的是谷歌浏览器,建议在设置中显示通知将本地服务地址加入允许通知

但是,http的域名在谷歌浏览器被默认关闭,还不允许更改,查看谷歌浏览器控制台有警告信息—>

index.js:78 [deprecation] the notification api may no longer be ud from incure origins. you should consider switching your application to a cure origin, such as https. e https://goo.gl/rsttgz for more details.

嗯,好吧,让加https证书,真的是有毒…虽然在自己的主页中添加该功能也只能在火狐浏览器爽一爽….

(腾讯云有免费一年的ssl证书,可自己进行安装…)

//青春诗歌 index.jswindow.onload = function(){  let gxllf = new gxllf()  gxllf.request广东高考分数线permission()  ttimeout(()=>{    gxllf.shownotification()  },3000)}class gxllf{   constructor(){    this.isnotificationsupported = "notification" in window;   }    ispermissiongranted(){        return notification.permission === 'granted';    }    requestpermission(){        if(!this.isnotificationsupported){            return;        }        notification.requestpermission(status=>{            let permission = notification.permission;        })    }    shownotification(){        if (!this.isnotificationsupported) {            return;        }        if (!this.ispermissiongranted()) {            return;        }        var n = new notification("gxllf对您发来问候", {    领巾        icon : 'gxllf.png',            body : '欢迎来访,鄙人万分感激! 点击即可跳转至我的博客页面~'        });        n.onshow = function () {            console.log('gxllf已经发送通知信息');            ttimeout(function() {                n.clo();            }, 5000);        }        n.onclick = function () {            location.href = '/d/file/titlepic/'            n.clo()        }        n.onerror = function (err) {            console.log(err)        }        n.onclo = function () {            很心console.log('gxllf消息窗口关闭')        }    }  }

这是火狐浏览器执行后的效果展示:

再来看看谷歌本地跑的效果:(域名已经被默认拦截关闭,上面已经说明,不再重复)

谷歌的效果其实挺好看的,嗯…只是一个https把我给屏蔽了 哎…

——- 桌面版应用 ———–

熊猫资料

当你要在开放 web 应用中使用通知时,请确保将 desktop-notification 权限添加到你的 manifest 文件中。通知可以被用于任何权限级别,hosted 或更高。

  "permissions": {      "desktop-notification":{}  }

这个notification比较好玩,也是未来发送消息的一个重要的一块,留此记录…希望对大家的学习有所帮助,也希望大家多多支持www.887551.com。

本文发布于:2023-04-03 08:46:06,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/f7bcc93a30146e3931ef9b0f8a6d8bfc.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:Html5中的桌面通知Notification的实现.doc

本文 PDF 下载地址:Html5中的桌面通知Notification的实现.pdf

标签:通知   事件   用户   对象
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图