现在企业主体的订阅消息是一次性的,由于公司需要多次发送消息,却又不符合长期性订阅消息条件,只能每次进行弹出授权。
在后台提供消息订阅id后,前端进行授权提示。以下代码适用于有长期性订阅服务id的企业或政府:
// 司机 - 消息订阅
requestMessage() {
var _this = this
var tmplIds = '***' // 用户同意的消息模板id
// 这里是获取下发权限地方,根据官方文档,可以根据 wx.getSetting() 的 withSubscriptions 这个参数获取用户是否打开订阅消息总开关。后面我们需要获取用户是否同意总是同意消息推送。所以这里要给它设置为true 。
wx.getSetting({
withSubscriptions: true, // 这里设置为true,下面才会返回mainSwitch
success: function(res){
// 调起授权界面弹窗
if (res.subscriptionsSetting.mainSwitch) { // 用户打开了订阅消息总开关
if (res.subscriptionsSetting.itemSettings != null) { // 用户同意总是保持是否推送消息的选择, 这里表示以后不会再拉起推送消息的授权
let moIdState = res.subscriptionsSetting.itemSettings[tmplIds]; // 用户同意的消息模板id
if(moIdState === 'accept'){
console.log('接受了消息推送');
}else if(moIdState === 'reject'){
console.log("拒绝消息推送");
}else if(moIdState === 'ban'){
console.log("已被后台封禁");
}
}else {
// 当用户没有点击 ’总是保持以上选择,不再询问‘ 按钮。那每次执到这都会拉起授权弹窗
wx.showModal({
title: '提示',
content:'请授权开通服务通知',
showCancel: true,
success: function (ress) {
if (ress.confirm) {
// console.log('用户点击确定')
wx.requestSubscribeMessage({ // 调起消息订阅界面
tmplIds: [tmplIds],
success (res) {
console.log('订阅消息 成功 ');
console.log(res);
},
fail (er){
console.log("订阅消息 失败 ");
console.log(er);
}
})
} else if (ress.cancel) {
// console.log('用户点击取消')
}
}
})
}
}else {
console.log('订阅消息未开启')
}
},
fail: function(error){
console.log(error);
}
})
},
普通企业只有一次性的订阅消息模板id,所以每次都要调用,不管是不是选择保持授权:
// 司机 - 消息订阅
requestMessage() {
var tmplIds = '***' // 用户同意的消息模板id
// 这里是获取下发权限地方,根据官方文档,可以根据 wx.getSetting() 的 withSubscriptions 这个参数获取用户是否打开订阅消息总开关。后面我们需要获取用户是否同意总是同意消息推送。所以这里要给它设置为true 。
wx.getSetting({
withSubscriptions: true, // 这里设置为true,下面才会返回mainSwitch
success: function(res){
// 调起授权界面弹窗
if (res.subscriptionsSetting.mainSwitch) { // 用户打开了订阅消息总开关
// 每次执到这都会拉起授权弹窗
wx.showModal({
title: '提示',
content:'请授权开通服务通知',
showCancel: true,
success: function (ress) {
if (ress.confirm) {
// console.log('用户点击确定')
wx.requestSubscribeMessage({ // 调起消息订阅界面
tmplIds: [tmplIds],
success (res) {
console.log('订阅消息 成功 ');
// console.log(res);
},
fail (er){
console.log("订阅消息 失败 ");
// console.log(er);
}
})
} else if (ress.cancel) {
// console.log('用户点击取消')
}
}
})
}else {
console.log('订阅消息未开启')
}
},
fail: function(error){
console.log(error);
}
})
},
目前所知的就这些,有错误的话欢迎告诉我进行补充纠正