博客
关于我
react native一键分享功能实现&原理和注意点(支持微信、qq、新浪微博等)
阅读量:461 次
发布时间:2019-03-06

本文共 1653 字,大约阅读时间需要 5 分钟。

前言

目前使用一键分享比较主流的两个SDK:ShareSDK、友盟。由于友盟功能较为全面,包含友盟统计、友盟推送等,本文将重点介绍友盟分享功能在React Native(RN)上的应用及需要注意的事项。

react native绑定SDK的两种方案

在实际开发中,绑定SDK的方式主要有以下两种:

  • 自己下载SDK包并手动集成

    需要从SDK官网下载对应的SDK包,按照步骤分别在Android和iOS上进行配置。然后在React Native项目中注册Package和Module,实现原生与RN之间的通讯。这种方式比较繁琐,但能完全自定义。

  • 使用现有开源或第三方方案

    借助其他开发者已经完成的Package和Module组件,直接将其引入RN项目中使用。这种方式相对懒人,但已经经过大量实践验证,代码复杂度较低,功能完整性较高。

  • 总结:两种方案各有优劣,选择时需根据项目需求权衡。现有开源方案在功能上已经接近最优化,建议优先考虑使用。

    一键分享实现方案

    本文将使用友盟(UMeng)作为分享SDK。具体使用版本为UMeng Social Tools,GitHub地址已移除,本文将重点阐述注意事项。

    注意事项(Android部分)

    除了GitHub文档中提到的10个步骤外,以下几点配置均为必不可少:

  • 修改相关代码包名

    需要在apsharemodulewxapiWBShareActivity.java中将相关包名替换为项目自身包名。

  • 添加必要的依赖

    在项目的build.gradle文件中添加如下依赖:

    dependencies {    // ... 其他依赖 ...    compile 'com.android.support:multidex:'    // ... 其他依赖 ...}
  • 启用Multi-dex支持

    defaultConfig中设置multiDexEnabled标签为true

    defaultConfig {    // ... 其他配置 ...    multiDexEnabled true    // ... 其他配置 ...}
  • 配置主应用类

    MainActivity.java中添加友盟统计相关引用:

    import com.umeng.analytics.MobclickAgent;import android.content.Intent;import android.os.Bundle;import com.umeng.socialize.UMShareAPI;
  • 应用程序入口配置

    MainApplication.java中引入必要的模块配置:

    import com.xxx.module.SharePackage; // 自定义包名import com.umeng.socialize.Config;import com.umeng.socialize.PlatformConfig;import com.umeng.socialize.UMShareAPI;
  • 常见问题与解决方案

    在完成上述配置后,可能会遇到以下错误:

    com.android.dex.DexIndexOverflowException: method ID not in [0, 0xffff]: 65935

    解决方法

  • 添加分包依赖

    build.gradle中添加multi-dex支持:

    dependencies {    // ... 其他依赖 ...    compile 'com.android.support:multidex:'    // ... 其他依赖 ...}
  • 启用Multi-dex支持

    在项目的build.gradle中添加以下配置:

    defaultConfig {    // ... 其他配置 ...    multiDexEnabled true    // ... 其他配置 ...}
  • 通过以上配置,应该能够解决该问题。

    转载地址:http://abwbz.baihongyu.com/

    你可能感兴趣的文章
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    Nginx配置文件nginx.conf中文详解(总结)
    查看>>
    Nginx配置负载均衡到后台网关集群
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>