【小程序】消息订阅requestSubscribeMessage

现在企业主体的订阅消息是一次性的,由于公司需要多次发送消息,却又不符合长期性订阅消息条件,只能每次进行弹出授权。
在这里插入图片描述
在后台提供消息订阅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);
      }
    })
  },

目前所知的就这些,有错误的话欢迎告诉我进行补充纠正

猜你喜欢

转载自blog.csdn.net/LuviaWu/article/details/119906017
今日推荐