前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >react-native 集成极光推送jpush-react-native时的小问题

react-native 集成极光推送jpush-react-native时的小问题

作者头像
mcq
发布2018-06-20 15:14:02
2.1K0
发布2018-06-20 15:14:02
举报

android的一个报错

... set canOverrideExistingModule=true

解决:

问题是在/android/app/src/java/.../MainApplication.java的getPackages()中重复引用了某个package,删除掉重复内容即可

新版中添加notifyJSDidLoad方法报错

  1. 如果不设平台,在ios里会报notifyJSDidLoad undefined错误
  2. 如果使用官方例子notifyJSDidLoad的代码,android会报cb方法undefined
// 在收到点击事件之前调用此接口
if(Platform.OS === 'android'){  //notifyJSDidLoad仅安卓有此方法

    // JPushModule.notifyJSDidLoad((resultCode) => {
    //    if (resultCode === 0) {}
    //  })
    //官网给的上面这种会报cb方法undefined错误

    JPushModule.notifyJSDidLoad(resultCode=>console.log(resultCode))
    //这样用不会报错,当然还有其他不会报错的写法。
}

后台带参传送时,前台拿到数据的结构不同平台不一样

JPushModule.addReceiveOpenNotificationListener(message=>{//用户点击通知事件

            //android和ios接收到的参数结构不同,需要分别处理获取

            if(Platform.OS==='android'){
                const {param1,param2} = JSON.parse(message.extras)

                ...  //对应的路由跳转或者其他操作
            }else{  //iOS
                const {param1,param2} = message

                ...  //对应的路由跳转或者其他操作
            }
}

android:const {param1,param2} = JSON.parse(message.extras)

iOS: const {param1,param2} = message

param1,param2改成你要接收的参数字段名

原理

因为iOS平台的推送是Apns推送,json格式不同,具体格式可以百度apns推送 json格式,如果懒可以点这里进行选购。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-09-28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • android的一个报错
  • 新版中添加notifyJSDidLoad方法报错
  • 后台带参传送时,前台拿到数据的结构不同平台不一样
    • 原理
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档