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

首頁 > 開發 > HTML5 > 正文

HTML5中的Web Notification桌面通知功能的實現方法

2024-09-05 07:22:56
字體:
來源:轉載
供稿:網友

有的時候我們會在桌面右下角看到這樣的提示:

這種桌面提示是HTML5新增的 Web Push Notifications 技術。

Web Notifications 技術使頁面可以發出通知,通知將被顯示在頁面之外的系統層面上。能夠為用戶提供更好的體驗,即使用戶忙于其他工作時也可以收到來自頁面的消息通知,例如一個新郵件的提醒,或者一個在線聊天室收到的消息提醒等等。

PS:除了IE外,各大現代瀏覽器都對這個桌面推送有了基本的支持。

開始

要創建一個消息通知,非常簡單,直接使用 window 對象下面的 Notification 類即可,代碼如下:

var n = new Notification("桌面推送", {    icon: 'img/icon.png',    body: '這是我的第一條桌面通知。',    image:'img/1.jpg'});

于是你就會看到系統桌面彈出我上面那張截圖的通知。

PS:消息通知只有通過 Web服務訪問 該頁面時才會生效,如果直接雙擊打開本地文件,是沒有任何效果的。也就是說你的文件需要使用服務器的形式打開,而不是直接使用瀏覽器打開本地文件。

當然也有可能你什么都沒看到,別著急繼續往下看。

基本語法

當然在想要彈出上面通知之前,有必要了解一下一個通知的基本語法:

let myNotification = new Notification(title, options);

title :定義一個通知的標題,當它被觸發時,它將顯示在通知窗口的頂部。

options (可選)對象包含應用于通知的任何自定義設置選項。

常用的選項有:

body: 通知的正文,將顯示在標題下方。

tag: 類似每個通知的ID,以便在必要的時候對通知進行刷新、替換或移除。

icon: 顯示通知的圖標

image: 在通知正文中顯示的圖像的URL。

data: 您想要與通知相關聯的任意數據。這可以是任何數據類型。

renotify: 一個 Boolean 指定在新通知替換舊通知后是否應通知用戶。默認值為false,這意味著它們不會被通知。

requireInteraction: 表示通知應保持有效,直到用戶點擊或關閉它,而不是自動關閉。默認值為false。

當這段代碼執行時,瀏覽器會詢問用戶,是否允許該站點顯示消息通知,如下圖所示:

只有用戶點擊了 允許 ,授權了通知,通知才會被顯示出來。

授權

如何獲取到用戶點擊的是“允許”還是“阻止”呢?

window的 Notification實例有一個 requestPermission 函數用來獲取用戶的授權狀態:

// 首先,我們檢查是否具有權限顯示通知  // 如果沒有,我們就申請權限  if (window.Notification && Notification.permission !== "granted") {      Notification.requestPermission(function (status) {      //status是授權狀態。      //如果用戶點擊的允許,則status為'granted'      // 如果用戶點擊的禁止,則status為'denied'           // 這將使我們能在 Chrome/Safari 中使用 Notification.permission      if (Notification.permission !== status) {        Notification.permission = status;      }    });  }

注意:如果用戶點擊了授權右上角的關閉按鈕,則status的值為default。

之后,我們只需要判斷 status 的值是否為 granted ,來決定是否顯示通知。

通知事件

但是單純的顯示一個消息框是沒有任何吸引力的,所以消息通知應該具有一定的交互性,在顯示消息的前前后后都應該有事件的參與。

Notification一開始就制定好了一系列事件函數,開發者可以很方面的使用這些函數處理用戶交互:

有: onshow , onclick , onerror , onclose 。

var n = new Notification("桌面推送", {    icon: 'img/icon.png',    body: '這是我的第一條桌面通知。'});//onshow函數在消息框顯示時觸發//可以做一些數據記錄及定時關閉消息框等n.onshow = function() {    console.log('顯示消息框');    //5秒后關閉消息框    setTimeout(function() {        n.close();    }, 3000);};//消息框被點擊時被調用//可以打開相關的視圖,同時關閉該消息框等操作n.onclick = function() {    console.log('點擊消息框');    // 打開相關的視圖    n.close();};//當有錯誤發生時會onerror函數會被調用//如果沒有granted授權,創建Notification對象實例時,也會執行onerror函數n.onerror = function() {    console.log('消息框錯誤');    // 做些其他的事};//一個消息框關閉時onclose函數會被調用n.onclose = function() {    console.log('關閉消息框');    //做些其他的事};

 

一個簡單的例子

<!DOCTYPE html><html lang="en">  <head>    <meta charset="UTF-8" />    <title>Document</title>  </head>  <body>    <button>點擊發起通知</button>  </body>  <script>    window.addEventListener("load", function() {      // 首先,讓我們檢查我們是否有權限發出通知      // 如果沒有,我們就請求獲得權限      if (window.Notification && Notification.permission !== "granted") {        Notification.requestPermission(function(status) {          if (Notification.permission !== status) {            Notification.permission = status;          }        });      }      var button = document.getElementsByTagName("button")[0];      button.addEventListener("click", function() {        // 如果用戶同意就創建一個通知        if (window.Notification && Notification.permission === "granted") {          var n = new Notification("Hi!");        }        // 如果用戶沒有選擇是否顯示通知        // 注:因為在 Chrome 中我們無法確定 permission 屬性是否有值,因此        // 檢查該屬性的值是否是 "default" 是不安全的。        else if (window.Notification && Notification.permission !== "denied") {          Notification.requestPermission(function(status) {            if (Notification.permission !== status) {              Notification.permission = status;            }            // 如果用戶同意了            if (status === "granted") {              var n = new Notification("Hi!");            }            // 否則,我們可以讓步的使用常規模態的 alert            else {              alert("Hi!");            }          });        }        // 如果用戶拒絕接受通知        else {          // 我們可以讓步的使用常規模態的 alert          alert("Hi!");        }      });    });  </script></html>

 

當我們打開界面的時候,就會彈出授權申請,如果我們點擊 允許 ,然后點擊按鈕,就可以發送一條通知到桌面,我們就可以在桌面右下角看到這條通知。

上面我們只是顯示一條消息。

if (status === "granted") {  var n = new Notification("Hi");}

如果我們有很多消息的話,比如我是用個for循環來模擬大量通知的情況。

for(var i=0; i<10; i++) {    var n = new Notification("Hi,"+i);}

可以看到有10條通知都顯示出來。但是某些情況下對于用戶來說,顯示大量通知是件令人痛苦的事情。

比如,如果一個即時通信應用向用戶提示每一條傳入的消息。為了避免數以百計的不必要通知鋪滿用戶的桌面,可能需要接管一個掛起消息的隊列。

因此,需要為新建的通知添加一個 標記 。

如果有一條新通知和上一條通知具有相同的標記,那么這條新通知將會替換上一條通知,最后桌面上只會顯示最新的通知。

還是上面的例子,只需要在觸發通知加個 tag 屬性即可:

 

for (var i = 0; i < 10; i++) {   // 最后只看到內容為 "Hi! 9" 的通知    var n = new Notification("Hi! " + i, {tag: 'soManyNotification'});}

最后

消息通知是個不錯的特性,可是也不排除有些站點惡意的使用這個功能,一旦用戶授權之后,不時的推送一些不太友好的消息,打擾用戶的工作,這個時候我們可以移除該站點的權限,禁用其消息通知功能。

我們可以點擊瀏覽器地址輸入框左邊的嘆號就有一個通知的選項,我們可以修改授權。或者在通知頁面也有修改通知的選項,可以根據具體情況進行修改授權通知。

于是最基本的 Web Notification 就實現了。

總結

以上所述是小編給大家介紹的HTML5中的Web Notification桌面通知功能的實現方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区二区三区乱码aⅴ| 亚洲天堂免费在线| 精品国产依人香蕉在线精品| 亚洲加勒比久久88色综合| 日韩精品免费视频| 97超碰国产精品女人人人爽| 亚洲国产精品热久久| 亚洲视频一区二区三区| 久久精品国产一区二区三区| 欧美日韩亚洲精品一区二区三区| 欧美成年人网站| 国产精品视频久久久| 亚洲在线免费视频| 久久久久国产精品免费| 国产成人欧美在线观看| 麻豆乱码国产一区二区三区| 国产裸体写真av一区二区| 久久亚洲私人国产精品va| 久久免费视频网| www.午夜精品| 日韩免费看的电影电视剧大全| 欧美成人精品不卡视频在线观看| 国产精品入口日韩视频大尺度| 欧美激情亚洲精品| 国产精品电影网站| 欧美做受高潮1| 亚洲欧美日韩国产成人| 日韩精品日韩在线观看| 中文字幕久久亚洲| 亚洲a区在线视频| 久久精品中文字幕| 精品国产区一区二区三区在线观看| 91精品国产自产在线老师啪| 欧美激情极品视频| 91国偷自产一区二区三区的观看方式| 欧美一级视频一区二区| 欧美性猛交xxxx乱大交蜜桃| 国产免费一区二区三区在线能观看| 亚洲第一天堂无码专区| 国产一区私人高清影院| 国产69精品久久久| 人妖精品videosex性欧美| 国产97在线播放| 亚洲午夜av久久乱码| 亚洲精品小视频在线观看| 亚洲视频第一页| 久久精品成人一区二区三区| 国产色婷婷国产综合在线理论片a| 亚洲色图在线观看| 大量国产精品视频| 国产精品久久久久久久久久99| 久久精品电影网| 91香蕉亚洲精品| 国产精品自产拍在线观看中文| 欧美激情视频在线免费观看 欧美视频免费一| 欧美一区视频在线| 久久久91精品国产一区不卡| 欧美国产极速在线| 国产精品一区二区在线| 国产乱肥老妇国产一区二| 国产不卡精品视男人的天堂| 日本亚洲欧美三级| 欧美黄色片免费观看| 久久精品国产久精国产一老狼| 久久av红桃一区二区小说| 91最新在线免费观看| 日韩欧美在线视频免费观看| 久久免费视频这里只有精品| 欧美性生交xxxxxdddd| 国产精品美乳在线观看| 亚洲国产日韩欧美在线图片| 欧美自拍视频在线| 久久99精品视频一区97| 国产成人精品在线播放| 亚洲最新中文字幕| 国产日韩在线看| 在线观看成人黄色| 日本午夜人人精品| 成人av在线天堂| 欧美中文字幕精品| 亚洲成人三级在线| 91亚洲精品一区二区| 亚洲色图综合网| 亚洲精品久久久久国产| 在线看片第一页欧美| 欧美一级电影在线| 欧美大人香蕉在线| 亚洲精品一区二区网址| 国色天香2019中文字幕在线观看| 国产一区二区成人| 亚洲精品福利免费在线观看| 国产视频精品自拍| 中文字幕成人精品久久不卡| 国语对白做受69| 国产精品高潮呻吟久久av黑人| 国产欧美一区二区| 国产日韩在线一区| 亚洲视频综合网| 成人写真视频福利网| 最近2019中文字幕mv免费看| 日本成熟性欧美| 成人欧美一区二区三区黑人| 国产成人涩涩涩视频在线观看| 2020欧美日韩在线视频| 国产欧美日韩精品丝袜高跟鞋| 91禁外国网站| 亚洲欧美日本伦理| 国语自产精品视频在线看一大j8| 亚洲a级在线播放观看| 91久久在线播放| 91成人性视频| 日本久久久久久| 一本色道久久综合狠狠躁篇的优点| zzijzzij亚洲日本成熟少妇| 国产精品免费一区二区三区都可以| 欧美性xxxxxxxxx| 亚洲色图狂野欧美| 国产欧美在线看| 成人久久久久久| 成人在线小视频| 97精品一区二区视频在线观看| 在线精品高清中文字幕| 亚洲精品久久久久久久久久久久久| 精品国产精品三级精品av网址| 亚洲aaaaaa| 亚洲电影免费在线观看| 久久久亚洲影院你懂的| 97国产真实伦对白精彩视频8| 亚洲国产精品资源| 久久久99久久精品女同性| 精品亚洲夜色av98在线观看| 日韩大片在线观看视频| 亚洲一区二区三区成人在线视频精品| 一区二区三区无码高清视频| 亚洲精品少妇网址| 欧美性受xxxx白人性爽| 国产精品999| 久久成人精品电影| 亚洲欧美制服中文字幕| 亚洲精品视频中文字幕| 精品久久久久久久久久ntr影视| 日韩美女写真福利在线观看| 亚洲国产小视频| 久久久精品美女| 欧美日韩国产精品一区| 欧美日韩综合视频网址| 日韩亚洲精品视频| 欧美最猛性xxxx| 精品呦交小u女在线| 亚洲欧美色图片| 中文字幕不卡在线视频极品| 国产一区二区三区三区在线观看| 日韩中文第一页| 国产精品久久久久久久久免费看| 欧美日本在线视频中文字字幕| 亚洲精品在线看| 精品无人区太爽高潮在线播放| 亚洲人成电影网站色www| 美乳少妇欧美精品| 亚洲伊人一本大道中文字幕| 亚洲娇小xxxx欧美娇小| 日韩视频免费在线观看| 国产午夜精品视频免费不卡69堂| 狠狠色狠狠色综合日日小说|