微信小程序一次性订阅封装

封装代码如下:

TypeScript 复制代码
export async function subscribeMessage(tmplIds: string[]): Promise<ISubscribeMessagePromise> {
  // 模板ID
  

  // 1、获取设置状态
  const settings = (await wx.getSetting({ withSubscriptions: true })).subscriptionsSetting || {}

  console.log('---设置状态---', settings)

  // 2、总开关
  if (!settings.mainSwitch) {
    return Promise.resolve({ content: '请在设置中打开消息订阅开关', status: false })
  }

  // 3、单个开关
  if (settings.itemSettings) {
    const notSubscribeTxt: string[] = []
    const yesSubscribeIds: string[] = []
    for (const item in settings.itemSettings) {
      if (settings.itemSettings[item] !== 'accept') {
        notSubscribeTxt.push(SUBSCRIBE_NOTICE[item])
        continue
      }
      yesSubscribeIds.push(item)
    }

    // 已订阅的消息增加次数 对应上边说的第4点,如果订阅多条,但是只允许接受一条消息,这里应增加允许消息的订阅次数,否则无法推送消息【遇到的坑】
    if (notSubscribeTxt.length && yesSubscribeIds.length) {
      wx.requestSubscribeMessage({ tmplIds: yesSubscribeIds, entityIds: [] })
    }
    if (notSubscribeTxt.length) {
      return Promise.resolve({ content: `请在设置中打开${notSubscribeTxt.join('、')}消息通知开关`, status: false })
    }
  }

  // 4、请求订阅
  return new Promise((resolve, reject) => {
    wx.requestSubscribeMessage({
      tmplIds: tmplIds,
      entityIds: [],
      success: function (res) {
        resolve({ content: '', status: true })
      },
      fail: function (err) {
        resolve({ content: '', status: true })
      }
    })
  })
}

调用

三、其他问题点

1、如果wx.getSetting获取到 mainSwitch=false 则需要引导用户去小程序设置里面打开总订阅开关

2、在设置中总开关打开,但是要订阅的消息选择不接受,则消息无法推送

3、wx.requestSubscribeMessage每调用一次,订阅次数增加1次【重要】

4、当《总保持以上选项》选中,但是消息订阅开关没有打开,需要引导用户去设置中打开消息(允许接受消息)。如果用户选择接受消息,回到页面也需要调用wx.requestSubscribeMessage来增加订阅次数,否则消息还是无法推送【重要】

相关推荐
少云清4 小时前
【功能测试】5_小程序项目 _抓包修改轮播图(重要)
小程序
深红4 小时前
玩转小程序AR-基础篇
前端·微信小程序·webvr
從南走到北4 小时前
JAVA代驾小程序源码代驾跑腿APP源码
java·开发语言·微信·微信小程序·小程序
小小王app小程序开发5 小时前
招工招聘小程序运营风险清单:资质备案 + 信息审核 + 服务履约避坑实操
小程序
2501_915921436 小时前
混合开发应用安全方案,在多技术栈融合下构建可持续、可回滚的保护体系
android·安全·ios·小程序·uni-app·iphone·webview
q_19132846956 小时前
基于SpringBoot2+Vue2+uniapp的考研社区论坛网站及小程序
java·vue.js·spring boot·后端·小程序·uni-app·毕业设计
pearbing7 小时前
多平台发力:小程序搜索优化的实用策略指南
小程序·小程序搜索排名·小程序优化·小程序搜索排名优化·小程序搜索优化·小程序seo
2501_915106327 小时前
Charles抓包怎么用 Charles抓包工具详细教程、网络调试方法、HTTPS配置与手机抓包实战
网络·ios·智能手机·小程序·https·uni-app·webview
00后程序员张8 小时前
Fastlane 结合 开心上架,构建跨平台可发布的 iOS 自动化流水线实践
android·运维·ios·小程序·uni-app·自动化·iphone
游戏开发爱好者88 小时前
iOS 性能测试的工程化方法,构建从底层诊断到真机监控的多工具测试体系
android·ios·小程序·https·uni-app·iphone·webview