使用 Javascript 實(shí)現(xiàn)瀏覽器推送提醒功能的示例
本篇文章內(nèi)容簡(jiǎn)單,速讀只需兩三分鐘,通過(guò)這兩三分鐘的時(shí)間你就可以給自己的網(wǎng)站實(shí)現(xiàn)推送提醒的功能
Notification 類
簡(jiǎn)單明了,這個(gè)類就是負(fù)責(zé)推送消息的,只要用戶當(dāng)前沒(méi)有關(guān)閉頁(yè)面,及時(shí)是在使用其他程序,瀏覽器也能夠?qū)⑾⑼扑徒o用戶
請(qǐng)求權(quán)限
我們?cè)谑謾C(jī)上都收到過(guò)消息推送,在接收推送之前我們會(huì)先將消息推送權(quán)限開(kāi)放給應(yīng)用。在瀏覽器中也一樣,在使用瀏覽器推送之前,需要先獲取權(quán)限
Notification.requestPermission().then(permission => { console.log(permission) })
通過(guò) requestPermission 方法可以為當(dāng)前域名請(qǐng)求消息推送的權(quán)限,這個(gè)方法可以使用 Promise 語(yǔ)法來(lái)實(shí)現(xiàn)請(qǐng)求結(jié)果的處理。當(dāng)然,你也可以使用回調(diào)的方式來(lái)實(shí)現(xiàn)
回調(diào)的參數(shù) permission 表示當(dāng)前請(qǐng)求后用戶的選擇:允許推送 / 不允許推送,它的值也分別有兩個(gè) granted / denied,當(dāng)我們發(fā)現(xiàn)用戶不允許的推送的時(shí)候,就可以在回調(diào)中做出相應(yīng)的提示,告訴用戶可能會(huì)導(dǎo)致不能及時(shí)接收消息,并且告訴用戶如果想要接收消息該如何操作等
查看權(quán)限
由于推送的權(quán)限是基于域名的,因此同一個(gè)網(wǎng)站在請(qǐng)求一次權(quán)限后,下一次打開(kāi)時(shí)就不會(huì)再次請(qǐng)求,而是直接通過(guò)第一次的用戶選擇來(lái)決定網(wǎng)站是否能向用戶推送
因此我們就需要能夠獲取到當(dāng)前網(wǎng)站的推送的狀態(tài),可以通過(guò)下面的這個(gè)屬性來(lái)獲取狀態(tài):
Notification.permission
permission 屬性的值有三種:granted - 允許推送;denied - 拒絕推送;default - 還未申請(qǐng)權(quán)限
當(dāng)值為 default 時(shí),我們就可以向用戶請(qǐng)求推送的權(quán)限了
發(fā)起一條推送
const note = new Notification (title, opts)
通過(guò)上面的方式可以聲明一條推送,它有兩個(gè)參數(shù),第一個(gè)參數(shù)是消息的標(biāo)題,這個(gè)是必填的一個(gè)參數(shù);而通過(guò)第二個(gè)選填參數(shù),我們則可以實(shí)現(xiàn)更多自定義的顯示內(nèi)容:
第二個(gè)參數(shù)接收一個(gè)對(duì)象,它有一下幾個(gè)屬性:
- body:推送的主體內(nèi)容
- tag:推送的標(biāo)識(shí),如果我們聲明了多個(gè) Notification,而這些推送的 tag 都相同,則只會(huì)推送一次
- icon:需要在推送中顯示的圖標(biāo)的 URL
- data:推送的消息所帶有的數(shù)據(jù)信息,當(dāng)用戶點(diǎn)擊推送窗口時(shí),可以通過(guò)這些信息為用戶展示相應(yīng)的內(nèi)容
- requireInteraction:正常情況下,推送發(fā)出后若用戶沒(méi)有操作,幾秒后就會(huì)消失,而將該屬性設(shè)為 true 則可以讓推送始終維持而不消失,默認(rèn)值是 false
當(dāng)我們需要自定義推送顯示時(shí)長(zhǎng)的時(shí)候,可以通過(guò)最后一個(gè)屬性將自動(dòng)消失關(guān)閉,然后配合 note.close() 和 setTimeout 方法人為控制推送時(shí)長(zhǎng)
點(diǎn)擊推送事件
既然已經(jīng)可以成功的發(fā)起一條推送,那么該如何監(jiān)聽(tīng)到用戶是否點(diǎn)擊了這個(gè)推送呢?很簡(jiǎn)單,通過(guò) onclick 屬性就可以實(shí)現(xiàn)
note.onclick = () => { //在這里實(shí)現(xiàn)用戶點(diǎn)擊后的邏輯 }
其他
需要注意的是,并不是所有瀏覽器都支持 Notification,所以在使用前需要先檢測(cè)能否使用
或許有的小伙伴會(huì)想,這個(gè)功能不錯(cuò),這樣在手機(jī)上也能實(shí)現(xiàn)網(wǎng)頁(yè)消息推送了。然而很不幸的是,移動(dòng)端瀏覽器幾乎100%不支持 Notification :(
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
輕松實(shí)現(xiàn)js選項(xiàng)卡切換效果
這篇文章主要幫助大家輕松實(shí)現(xiàn)js選項(xiàng)卡切換效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09原生JS實(shí)現(xiàn)圣旨卷軸展開(kāi)效果
本文主要介紹了原生JS實(shí)現(xiàn)詔書(shū)卷軸展開(kāi)效果的實(shí)例,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03淺析Javascript ES6新增值比較函數(shù)Object.is
在Javascript中判斷相等是很常見(jiàn)的,常用的判斷有“==”,“===”,“!=”,“!==”,今天這篇文章我們來(lái)學(xué)習(xí)ES6中的一個(gè)方法Object.is(),有需要的可以參考學(xué)習(xí)。2016-08-08php和js對(duì)數(shù)據(jù)庫(kù)圖片進(jìn)行等比縮放示例
這篇文章主要介紹了php和js如何對(duì)數(shù)據(jù)庫(kù)圖片進(jìn)行等比縮放,需要的朋友可以參考下2014-04-04javascript命名約定(變量?函數(shù)?類?組件)
這篇小文章主要是通過(guò)一些例子來(lái)介紹一些Javascript中一些關(guān)于命名變量,函數(shù),類或者是組件的通用約定,雖然這些規(guī)則并不是強(qiáng)制性的,但是呢,他們卻被一些JS社區(qū)所廣泛采用,所以,了解他們還是很有必要的2023-03-03一個(gè)可以得到元素真實(shí)的背景顏色的javascript腳本
一個(gè)可以得到元素真實(shí)的背景顏色的javascript腳本...2007-07-07微信小程序如何修改本地緩存key中單個(gè)數(shù)據(jù)的詳解
這篇文章主要介紹了微信小程序如何修改本地緩存key中單個(gè)數(shù)據(jù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04js實(shí)現(xiàn)日期顯示的一些操作(實(shí)例講解)
下面小編就為大家?guī)?lái)一篇js實(shí)現(xiàn)日期顯示的一些操作(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07