<!DOCTYPE HTML>
|
<html>
|
<head>
|
<meta charset="utf-8" />
|
<meta name="viewport" content="initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
|
<meta name="HandheldFriendly" content="true" />
|
<meta name="MobileOptimized" content="320" />
|
<title>Hello H5+</title>
|
<script type="text/javascript" src="../js/common.js"></script>
|
<script type="text/javascript">
|
var pushServer = "http://demo.dcloud.net.cn/push/?";
|
var message = null;
|
// 监听plusready事件
|
document.addEventListener("plusready", function() {
|
message = document.getElementById("message");
|
// 监听点击消息事件
|
plus.push.addEventListener("click", function(msg) {
|
// 判断是从本地创建还是离线推送的消息
|
switch (msg.payload) {
|
case "LocalMSG":
|
outSet("点击本地创建消息启动:");
|
break;
|
default:
|
outSet("点击离线推送消息启动:");
|
break;
|
}
|
// 提示点击的内容
|
plus.nativeUI.alert(msg.content);
|
// 处理其它数据
|
logoutPushMsg(msg);
|
}, false);
|
// 监听在线消息事件
|
plus.push.addEventListener("receive", function(msg) {
|
if (msg.aps) { // Apple APNS message
|
outSet("接收到在线APNS消息:");
|
} else {
|
outSet("接收到在线透传消息:");
|
}
|
logoutPushMsg(msg);
|
}, false);
|
}, false);
|
|
/**
|
* 日志输入推送消息内容
|
*/
|
function logoutPushMsg(msg) {
|
outLine("title: " + msg.title);
|
outLine("content: " + msg.content);
|
if (msg.payload) {
|
if (typeof(msg.payload) == "string") {
|
outLine("payload(String): " + msg.payload);
|
} else {
|
outLine("payload(JSON): " + JSON.stringify(msg.payload));
|
}
|
} else {
|
outLine("payload: undefined");
|
}
|
if (msg.aps) {
|
outLine("aps: " + JSON.stringify(msg.aps));
|
}
|
}
|
|
/**
|
* 获取本地推送标识信息
|
*/
|
function getPushInfo() {
|
outSet("获取客户端推送标识信息:");
|
plus.push.getClientInfoAsync(function(info) {
|
outLine('Success');
|
outLine(JSON.stringify(info));
|
}, function(e) {
|
outLine('Failed');
|
outLine(JSON.stringify(e));
|
});
|
}
|
/**
|
* 本地创建一条推动消息
|
*/
|
function createLocalPushMsg() {
|
var options = {
|
cover: false
|
};
|
var str = dateToStr(new Date());
|
str += ": 欢迎使用HTML5+创建本地消息!";
|
plus.push.createMessage(str, "LocalMSG", options);
|
outSet("创建本地消息成功!");
|
outLine("请到系统消息中心查看!");
|
if (plus.os.name == "iOS") {
|
outLine('*如果无法创建消息,请到"设置"->"通知"中配置应用在通知中心显示!');
|
}
|
}
|
/**
|
* 读取所有推送消息
|
*/
|
function listAllPush() {
|
var msgs = null;
|
switch (plus.os.name) {
|
case "Android":
|
msgs = plus.push.getAllMessage();
|
break;
|
default:
|
break;
|
}
|
if (!msgs) {
|
outSet("此平台不支持枚举推送消息列表!");
|
return;
|
}
|
outSet("枚举消息列表(" + msgs.length + "):");
|
for (var i in msgs) {
|
var msg = msgs[i];
|
outLine(i + ": " + msg.title + " - " + msg.content);
|
}
|
}
|
/**
|
* 清空所有推动消息
|
*/
|
function clearAllPush() {
|
plus.push.clear();
|
outSet("清空所有推送消息成功!");
|
}
|
/**
|
* 请求‘简单通知’推送消息
|
*/
|
function requireNotiMsg() {
|
if (navigator.userAgent.indexOf('StreamApp') > 0) {
|
plus.nativeUI.toast('当前环境暂不支持发送推送消息');
|
return;
|
}
|
var inf = plus.push.getClientInfo();
|
var url = pushServer + 'type=noti&appid=' + encodeURIComponent(plus.runtime.appid);
|
inf.id && (url += '&id=' + inf.id);
|
url += ('&cid=' + encodeURIComponent(inf.clientid));
|
if (plus.os.name == 'iOS') {
|
url += ('&token=' + encodeURIComponent(inf.token));
|
}
|
url += ('&title=' + encodeURIComponent('Hello H5+'));
|
url += ('&content=' + encodeURIComponent('欢迎回来体验HTML5 plus应用!'));
|
url += ('&version=' + encodeURIComponent(plus.runtime.version));
|
plus.runtime.openURL(url);
|
}
|
/**
|
* 请求‘打开网页’推送消息
|
*/
|
function requireLinkMsg() {
|
if (navigator.userAgent.indexOf('StreamApp') > 0) {
|
plus.nativeUI.toast('当前环境暂不支持发送推送消息');
|
return;
|
}
|
var inf = plus.push.getClientInfo();
|
var url = pushServer + "type=link&appid=" + encodeURIComponent(plus.runtime.appid);
|
inf.id && (url += '&id=' + inf.id);
|
url += ('&cid=' + encodeURIComponent(inf.clientid));
|
if (plus.os.name == 'iOS') {
|
url += ('&token=' + encodeURIComponent(inf.token));
|
}
|
url += ('&title=' + encodeURIComponent('HBuilder飞一样的编码'));
|
url += ('&content=' + encodeURIComponent('看HBuilder如何追求代码编写速度的极致!立即去瞧一瞧?'));
|
url += ('&url=' + encodeURIComponent('http://www.dcloud.io/'));
|
url += ('&version=' + encodeURIComponent(plus.runtime.version));
|
plus.runtime.openURL(url);
|
}
|
/**
|
* 请求‘下载链接’推送消息
|
*/
|
function requireDownMsg() {
|
if (navigator.userAgent.indexOf('StreamApp') > 0) {
|
plus.nativeUI.toast('当前环境暂不支持发送推送消息');
|
return;
|
}
|
if (plus.os.name != "Android") {
|
plus.nativeUI.alert("此平台不支持!");
|
return;
|
}
|
var inf = plus.push.getClientInfo();
|
var url = pushServer + 'type=down&appid=' + encodeURIComponent(plus.runtime.appid);
|
inf.id && (url += '&id=' + inf.id);
|
url += ('&cid=' + encodeURIComponent(inf.clientid));
|
url += ('&title=' + encodeURIComponent('Hello H5+'));
|
url += ('&content=' + encodeURIComponent('新版本发布了!立即下载体验?'));
|
url += ('&ptitle=' + encodeURIComponent('Hello H5+'));
|
url += ('&pcontent=' + encodeURIComponent('1. 优化用户体验;\n2. 修复在Android2.3.x某些设备可能异常退出的问题.'));
|
url += ('&dtitle=' + encodeURIComponent('下载Hello H5+'));
|
url += ('&durl=' + encodeURIComponent('http://www.dcloud.io/helloh5/HelloH5.apk'));
|
url += ('&version=' + encodeURIComponent(plus.runtime.version));
|
plus.runtime.openURL(url);
|
}
|
/**
|
* 请求‘透传数据’推送消息
|
*/
|
function requireTranMsg() {
|
if (navigator.userAgent.indexOf('StreamApp') > 0) {
|
plus.nativeUI.toast('当前环境暂不支持发送推送消息');
|
return;
|
}
|
var inf = plus.push.getClientInfo();
|
var url = pushServer + 'type=tran&appid=' + encodeURIComponent(plus.runtime.appid);
|
inf.id && (url += '&id=' + inf.id);
|
url += ('&cid=' + encodeURIComponent(inf.clientid));
|
if (plus.os.name == 'iOS') {
|
url += ('&token=' + encodeURIComponent(inf.token));
|
}
|
url += ('&title=' + encodeURIComponent('Hello H5+'));
|
url += ('&content=' + encodeURIComponent('带透传数据推送通知,可通过plus.push API获取数据并进行业务逻辑处理!'));
|
url += ('&payload=' + encodeURIComponent(
|
'{"title":"Hello H5+ Test","content":"test content","payload":"1234567890"}'));
|
url += ('&version=' + encodeURIComponent(plus.runtime.version));
|
plus.runtime.openURL(url);
|
}
|
</script>
|
<link rel="stylesheet" href="../css/common.css" type="text/css" charset="utf-8" />
|
</head>
|
<body>
|
<br />
|
<div class="button" onclick="requireNotiMsg()">发送"普通通知"消息</div>
|
<div class="button" onclick="requireLinkMsg()">发送"打开网页"消息</div>
|
<div class="button" onclick="requireDownMsg()">发送"下载链接"消息</div>
|
<div class="button" onclick="requireTranMsg()">发送"透传数据"消息</div>
|
<br />
|
<ul id="dlist" class="dlist">
|
<li class="ditem" onclick="getPushInfo()">获取客户端推送标识</li>
|
<li class="ditem" onclick="createLocalPushMsg()">创建本地消息</li>
|
<li class="ditem" onclick="listAllPush()">枚举推送消息</li>
|
<li class="ditem" onclick="clearAllPush()">清空推送消息</li>
|
<!--<li class="ditem" onclick="plus.push.setAutoNotification(false)">关闭自动显示消息</li>
|
<li class="ditem" onclick="plus.push.setAutoNotification(true)">开启自动显示消息</li>-->
|
</ul>
|
<div id="outpos" />
|
<div id="output">
|
Push模块管理推送消息功能,可以实现在线、离线的消息推送,通过plus.push可获取推送消息管理对象。
|
</div>
|
</body>
|
</html>
|