国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > HTML > 正文

html5 桌面提醒:Notifycations應(yīng)用介紹

2024-08-26 00:16:20
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

點(diǎn)評(píng):HTML5中的桌面提醒(web notifications)可以在當(dāng)前頁(yè)面窗口彈出一個(gè)消息框,這個(gè)消息框是跨Tab 窗口的,這在用戶打開多個(gè) tab 瀏覽網(wǎng)頁(yè)時(shí),提醒比較方便,容易讓用戶看到

HTML5中的桌面提醒(web notifications)可以在當(dāng)前頁(yè)面窗口彈出一個(gè)消息框,這個(gè)消息框是跨 Tab 窗口的,這在用戶打開多個(gè) tab 瀏覽網(wǎng)頁(yè)時(shí),提醒比較方便,容易讓用戶看到。目前只要是 webkit 內(nèi)核支持該功能。
該功能在 chrome 下需要以 http 方式打開網(wǎng)頁(yè)才能啟用。
桌面提醒功能由 window.webkitNotifications 對(duì)象實(shí)現(xiàn)(webkit內(nèi)核)。
window.webkitNotifications 對(duì)象沒有屬性,有四個(gè)方法:
1.requestPermission()
  該方法用于向用戶申請(qǐng)消息提醒權(quán)限,如果當(dāng)前沒有開放該權(quán)限,瀏覽器將彈出授權(quán)界面,用戶授權(quán)后,在對(duì)象內(nèi)部產(chǎn)生一個(gè)狀態(tài)值(一個(gè)0、1或 2 的整數(shù)):
0:表示用戶同意消息提醒,只在該狀態(tài)下可以使用信息提醒功能;
1:表示默認(rèn)狀態(tài),用戶既未拒絕,也未同意;
2:表示用戶拒絕消息提醒。
2.checkPermission()
  這個(gè)方法用于獲取 requestPermission() 申請(qǐng)到的權(quán)限的狀態(tài)值。
3.createNotification()
  這個(gè)方法以純消息的方式創(chuàng)建提醒消息,它接受三個(gè)字符串參數(shù):
iconURL:在消息中顯示的圖標(biāo)地址,
title:消息的標(biāo)題,
body:消息主體文本內(nèi)容
該方法會(huì)返回一個(gè) Notification對(duì)象,可以針對(duì)這個(gè)對(duì)象做更多的設(shè)置。
Notification 對(duì)象的屬性與方法:

復(fù)制代碼

代碼如下:


dir: ""
onclick: null
onclose: null
ondisplay: function (event) {
onerror: null
onshow: null
replaceId: ""
tag: ""
__proto__: Notification
addEventListener: function addEventListener() { [native code] }
cancel: function cancel() { [native code] }
close: function close() { [native code] }
constructor: function Notification() { [native code] }
dispatchEvent: function dispatchEvent() { [native code] }
removeEventListener: function removeEventListener() { [native code] }
show: function show() { [native code] }
__proto__: Object


dir:設(shè)置消息的排列方向,可取值為“auto”(自動(dòng)), “ltr”(left to right), “rtl”(right to left)。
  tag:為消息添加標(biāo)簽名。如果設(shè)置此屬性,當(dāng)有新消息提醒時(shí),標(biāo)簽相同的消息只顯示在同一個(gè)消息框,后一個(gè)消息框會(huì)替換先前一個(gè),否則出現(xiàn)多個(gè)消息提示框,但是最多值顯示3個(gè)消息框,超過(guò)3個(gè),后繼消息通知會(huì)被阻塞。
  onshow:當(dāng)消息框顯示的時(shí)候觸發(fā)該事件;
  onclick: 當(dāng)點(diǎn)擊消息框的時(shí)候觸發(fā)該事件;
  onclose:當(dāng)消息關(guān)閉的時(shí)候觸發(fā)該事件;
  onerror:當(dāng)出現(xiàn)錯(cuò)誤的時(shí)候觸發(fā)該事件;
方法:
  addEventListener && removeEventListener:常規(guī)的添加和移除事件方法;
  show:顯示消息提醒框;
  close:關(guān)閉消息提醒框;
  cancel:關(guān)閉消息提醒框,和 close一樣;
4.createHTMLNotification()
  該方法與 createNotification() 不同的是,他以HTML方式創(chuàng)建消息,接受一個(gè)參數(shù): HTML 文件的URL,該方法同樣返回 Notification對(duì)象。
一個(gè)實(shí)例:

復(fù)制代碼

代碼如下:


<!DOCTYPE HTML>
<html>
<head>
<title>notifications in HTML5</title>
</head>
<body>
<form>
<input type="button" value="Send notification" />
</form>
<script type="text/javascript">
document.getElementById("trynotification").onclick = function(){
notify(Math.random());
};
function notify(tab) {
if (!window.webkitNotifications) {
return false;
}
var permission = window.webkitNotifications.checkPermission();
if(permission!=0){
window.webkitNotifications.requestPermission();
var requestTime = new Date();
var waitTime = 5000;
var checkPerMiniSec = 100;
setTimeout(function(){
permission = window.webkitNotifications.checkPermission();
if(permission==0){
createNotification(tab);
}else if(new Date()-requestTime<waitTime){
setTimeout(arguments.callee,checkPerMiniSec);
}
},checkPerMiniSec);
}else if(permission==0){
createNotification(tab);
}
}
function createNotification(tab){
var showSec = 10000;
var icon = "http://tech.baidu.com/resource/img/logo_news_137_46.png";
var + new Date().toLocaleTimeString() + "] close after " + (showSec/1000) + " seconds";
var body = "hello world, i am webkitNotifications informations";
var popup = window.webkitNotifications.createNotification(icon, title, body);
popup.tag = tab;
popup.ondisplay = function(event) {
setTimeout(function() {
event.currentTarget.cancel();
}, showSec);
}
popup.show();
}
</script>
</body>
</html>


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 喀什市| 城步| 沙湾县| 西和县| 广河县| 汽车| 东宁县| 新和县| 石台县| 沂源县| 大城县| 滦平县| 阿克陶县| 西华县| 南康市| 从化市| 古蔺县| 宝应县| 榕江县| 平阳县| 蓝田县| 威海市| 唐山市| 门头沟区| 镇雄县| 加查县| 宜春市| 文登市| 上饶县| 仪陇县| 泰安市| 克什克腾旗| 荆门市| 龙川县| 周宁县| 南京市| 丁青县| 和顺县| 应城市| 安多县| 隆子县|