亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

Html5中的桌面通知Notification的實現

2024-08-26 00:21:02
字體:
來源:轉載
供稿:網友

前言:對于一個前段開發者,逛網頁總會留意一些新奇的功能,對于上班總會用到Teambition的我,總是能收到Notification...所以今天就來研究下這個H5功能...

1. 實例一個Notification

let n = new Notification(  "這是一個通知消息", //這是必選Title 一定會顯示的通知標題  {    icon: "xxx.png", // 這個icon是用來顯示通知中的左邊圖片    body: "你好啊,我是xxx",   // 通知中的內容字符    dir: auto,             // 文字的方向 值包含: auto(自動), ltr(從左到右), rtl(從右向左)    tag: "gxlself"          // 給與這個通知消息一個ID, 用來對這個通知消息進行 刷新.移除.替換 等操作    // long: "en-US"               //lang字段 需要參考https://tools.ietf.org/html/bcp47 并不是必須 沒看出啥作用...    // ...            // 其余可選屬性見下實例屬性  })

訪問對應的實例屬性:
n.actions // 一個只讀的NotificationAction對象數組。每一個對象描述用戶可以在一個通知中選擇的單個操作。
n.image // 通知的一部分顯示的圖像的URL
n.badge // 當沒有足夠的空間顯示通知本身時,用于表示通知的圖像的URL。
n.permission // 有三個值 granteddenied, 或default 當狀態值為granted時可以發送通知消息 default默認用戶沒處理 denied 用戶拒絕 
n.renotify // 布爾值。新通知出現的時候是否替換之前的。如果設為true,則表示替換,表示當前標記的通知只會出現一個。注意這里的“當前標記”沒?沒錯,true參數要想起作用,tag必須需要設置屬性值。
n.requireInteraction // 布爾值, 指的是通知是否保持活動直到用戶點擊或取消通知 而不是自動關閉..
n.silent // 布爾值。通知出現的時候,是否要有聲音。默認false, 表示無聲。
n.timestamp //通知創建或者可以使用的時間。
n.data // 任意類型和通知相關聯的數據。
n.vibrate // 通知顯示時候,設備震動硬件需要的震動模式。所謂振動模式,指的是一個描述交替時間的數組,分別表示振動和不振動的毫秒數,一直交替下去。例如[200, 100, 200]表示設備振動200毫秒,然后停止100毫秒,再振動200毫秒。 (移動端)
n.sound // 字符串。音頻地址。表示通知出現要播放的聲音資源。
n.sticky // 通知吸附不容易被清除... (移動端)
n.noscreen // 布爾值。是否不再屏幕上顯示通知信息。默認false, 表示要在屏幕上顯示通知內容。(移動端)

此時實例 n 有四個事件處理: 
1> onclick 用戶對通知信息的點擊事件
2> onshow 通知消息展示之后觸發的事件 
3> onerror 遇到錯誤會觸發的事件
4> onclose close事件的處理

2. Notification對象會有什么屬性/方法呢?利用控制臺中的window對象輸出點開查看就可以看到:

Html5,桌面通知,Notification

值得注意的是: requestPermission()方法僅在Notification對象有效,實例對象無效!!!這個方法是用來向用戶申請顯示通知的權限,只能被用戶主動去調用(在頁面onload中可以調用,可以向用戶申請,之后再去發送...)

實例對象擁有的方法有:

    (1). close() 用于關閉通知消息 --> 也可以在onshow方法加延遲調用,提高用戶體驗感...

    (2). addEventListener() 監聽事件(這個通用方法)

    (3). removeEventListener 卸載監聽事件(通用,同上)

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

接下來,寫一個js測試, 如果使用的是谷歌瀏覽器,建議在設置中顯示通知將本地服務地址加入允許通知

但是,http的域名在谷歌瀏覽器被默認關閉,還不允許更改,查看谷歌瀏覽器控制臺有警告信息--->

index.js:78 [Deprecation] The Notification API may no longer be used from insecure origins. You should consider switching your application to a secure origin, such as HTTPS. See https://goo.gl/rStTGz for more details.

嗯,好吧,讓加https證書,真的是有毒...雖然在自己的主頁中添加該功能也只能在火狐瀏覽器爽一爽....

(騰訊云有免費一年的ssl證書,可自己進行安裝...)

// index.jswindow.onload = function(){  let gxlself = new Gxlself()  gxlself.requestPermission()  setTimeout(()=>{    gxlself.showNotification()  },3000)}class Gxlself{   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("gxlself對您發來問候", {            icon : 'gxlself.png',            body : '歡迎來訪,鄙人萬分感激! 點擊即可跳轉至我的博客頁面~'        });        n.onshow = function () {            console.log('gxlself已經發送通知信息');            setTimeout(function() {                n.close();            }, 5000);        }        n.onclick = function () {            location.href = 'http://gxlself.com/blog'            n.close()        }        n.onerror = function (err) {            console.log(err)        }        n.onclose = function () {            console.log('gxlself消息窗口關閉')        }    }  }

這是火狐瀏覽器執行后的效果展示:

Html5,桌面通知,Notification

再來看看谷歌本地跑的效果:(域名已經被默認攔截關閉,上面已經說明,不再重復)

Html5,桌面通知,Notification

谷歌的效果其實挺好看的,嗯...只是一個https把我給屏蔽了 哎...

------- 桌面版應用 -----------

當你要在開放 web 應用中使用通知時,請確保將 desktop-notification 權限添加到你的 manifest 文件中。通知可以被用于任何權限級別,hosted 或更高。

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

這個Notification比較好玩,也是未來發送消息的一個重要的一塊,留此記錄...希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美在线激情网| 亚洲开心激情网| 亚洲国产天堂久久综合网| 欧美电影免费在线观看| 久久久久久久久久亚洲| 日韩欧美在线播放| 精品久久久久久久久久久久| 久久97精品久久久久久久不卡| 国产精品入口福利| 久久天堂av综合合色| 久久久久久久999精品视频| 另类色图亚洲色图| 欧美亚洲一级片| 亚洲自拍偷拍色片视频| 韩国精品久久久999| 亚洲视频日韩精品| 精品亚洲国产成av人片传媒| 日韩成人在线电影网| 国产精品第二页| 欧美成年人视频| 一区二区三区视频在线| xxxxxxxxx欧美| 国产九九精品视频| 97精品久久久中文字幕免费| 色悠悠久久久久| 精品久久香蕉国产线看观看亚洲| 亚洲精品美女在线观看| 日韩av网站电影| 中文字幕精品av| 欧美激情啊啊啊| 国产精品日韩专区| 97香蕉超级碰碰久久免费的优势| 国产精品爽爽爽| 日韩美女免费视频| 精品国产31久久久久久| 国产精品∨欧美精品v日韩精品| 欧美性猛交丰臀xxxxx网站| 成人信息集中地欧美| 精品国产区一区二区三区在线观看| 欧美日韩精品在线观看| 成人黄色在线观看| 色综合男人天堂| 亚洲精品乱码久久久久久按摩观| 美女视频黄免费的亚洲男人天堂| 欧美最顶级的aⅴ艳星| 久久久久久久久91| 欧美激情在线狂野欧美精品| 亚洲欧美视频在线| 欧美在线免费视频| 国产成人精品免高潮在线观看| 懂色av中文一区二区三区天美| 不卡av电影在线观看| 2019亚洲日韩新视频| 欧美激情精品久久久久久| 欧美丝袜一区二区| 久久综合九色九九| 国产欧美精品在线播放| 日韩精品视频免费在线观看| 亚洲a级在线播放观看| 国产精品日韩专区| 国产精品高清在线观看| 爱福利视频一区| 日韩美女主播视频| 国产精品日韩久久久久| 欧美午夜影院在线视频| 久久69精品久久久久久国产越南| 国产精品稀缺呦系列在线| 亚洲韩国日本中文字幕| 欧美精品一区二区免费| 91免费电影网站| 国产福利精品在线| 欧美洲成人男女午夜视频| 国产欧美日韩丝袜精品一区| 欧美高清视频免费观看| 91精品国产乱码久久久久久久久| 亚洲人成在线观| 在线视频日韩精品| 日韩欧美精品免费在线| 久久精品人人爽| 欧美极品少妇与黑人| 亚洲91av视频| 日韩国产欧美精品在线| 亚洲精品第一国产综合精品| 91在线观看免费高清完整版在线观看| 成人午夜小视频| 日韩av免费一区| 51精品国产黑色丝袜高跟鞋| 亚洲欧洲国产精品| 国产成人精品a视频一区www| 热久久视久久精品18亚洲精品| 91国产精品视频在线| 久久国产精品免费视频| 国产精品爽爽ⅴa在线观看| 国产精品美女在线观看| 91精品国产91| 欧美小视频在线观看| 久久久久国产一区二区三区| 国内成人精品一区| 久久天天躁狠狠躁夜夜躁| 久久久91精品国产一区不卡| 91福利视频网| 欧美黑人xxx| 亚洲码在线观看| 久久久欧美精品| 国产亚洲精品一区二区| 亚洲高清不卡av| 亚洲综合社区网| 成人激情视频免费在线| 欧美日韩亚洲天堂| 成人免费大片黄在线播放| 岛国精品视频在线播放| 日韩成人在线播放| 久久偷看各类女兵18女厕嘘嘘| 在线a欧美视频| 欧美日韩一区二区免费在线观看| 久久九九有精品国产23| 亚洲欧美精品中文字幕在线| 欧美激情在线狂野欧美精品| 国产精品久久久久久久天堂| 国产精品高潮粉嫩av| 九九精品视频在线观看| 亚洲欧美日韩视频一区| 91久久精品国产91久久性色| 亚洲国产一区自拍| 国产精品中文字幕久久久| 成人免费视频在线观看超级碰| 亚洲精品久久久久中文字幕二区| 国内精品久久久久久中文字幕| 欧美美女操人视频| 欧美刺激性大交免费视频| 国产精品第七影院| 亚洲精品久久在线| 亚洲第一福利视频| 成人久久一区二区三区| 亚洲欧美一区二区三区四区| 国产日韩精品一区二区| 欧美激情国产日韩精品一区18| 91网在线免费观看| 日韩欧美精品在线观看| 国精产品一区一区三区有限在线| 国产成人在线亚洲欧美| 欧美日韩在线影院| 国产精品视频999| 精品国产一区二区三区久久狼黑人| 久久精品视频一| 亚洲专区中文字幕| 国产噜噜噜噜噜久久久久久久久| 亚洲国产另类久久精品| 最近2019中文字幕第三页视频| 国产三级精品网站| 4444欧美成人kkkk| 亚洲v日韩v综合v精品v| 久久男人av资源网站| 日韩黄色高清视频| 亚洲黄在线观看| 在线日韩av观看| 欧美高清视频在线| 久久久精品中文字幕| 国产精品人成电影| 国产精品十八以下禁看| 日韩欧美中文第一页| 日韩在线视频观看| 久久久精品久久久| 国产日韩欧美91|