rn+android+sdk,React Native SDK

React Native SDK

诸葛io移动统计支持React Native插件,以下为集成方法。

1. 环境准备

1.1. iOS环境

iOS 8.0+

代码支持iOS8.0的系统

pod 1.0+

iOS系统的集成依赖于cocoaPod工具

1.2. Android环境

Android SDK 16+

代码支持Android 16+

1.3. React Native环境

react-native 0.50+

react-native-cli 2.0+

项目本身基于以上版本的React Native开发。目前不确定是否支持低版本的React Native。若集成不成功,请联系我们。

2. 集成方法

打开终端,在React Native项目目录下执行:

$ yarn add react-native-plugin-zhugeio

$ npm install react-native-plugin-zhugeio --save

$ react-native link

2.1. iOS集成

若React Native项目的iOS文件夹下,没有Podfile文件,需要初始化Pod:

$ pod init

以上命令将在iOS目录下创建Podfile文件。

编辑Podfile文件

platform :ios, '8.0'

target 'yourApp' do

pod 'yoga', :path => '../node_modules/react-native/ReactCommon/yoga'

pod 'React', path: '../node_modules/react-native',:subspecs => ['DevSupport']

pod 'react-native-plugin-zhugeio', path: '../node_modules/react-native-plugin-zhugeio'

end

执行pod install

在ios/youProjectName/AppDelegate.m文件中,找到application didFinishLaunchingWithOptions方法,在其中加入如下代码:

#import

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

[[Zhuge sharedInstance] startWithAppKey:@"Your App Key" launchOptions:launchOptions];

}若是私有部署的用户,需要更改数据上传地址,请将上述代码更改为:

#import

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

//设置上传地址,一般用户无需更改

[[Zhuge sharedInstance] setUploadURL:@"https://www.zhugeio.com" andBackupUrl:nil];

[[Zhuge sharedInstance] startWithAppKey:@"Your App Key" launchOptions:launchOptions];

}

2.2. Android集成

检查android/setting.gradle配置是否包含如下内容:

include ':react-native-plugin-zhugeio'

project(':react-native-plugin-zhugeio').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-plugin-zhugeio/android')

检查android/app/build.gradledependencies是否包含如下内容:

implementation project(':react-native-plugin-zhugeio')

找到 android/youApp/src/main/java.../MainApplication.java 文件,添加如下代码:

import com.zhuge.analysis.stat.ZhugeSDK;//

import com.zhuge.reactnativezhuge.RNZhugeioPackage;//

public class MainApplication extends Application implements ReactApplication {

@Override

public void onCreate(){

Super.onCreate();

...

//ZhugeSDK初始化

ZhugeSDK.getInstance().init(this,"yourAppKey","youAppChannel");

...

}

// 如果不能自动连接 RNZhugeioPackage

@Override

protected List getPackages() {

@SuppressWarnings("UnnecessaryLocalVariable")

List packages = new PackageList(this).getPackages();

// Packages that cannot be autolinked yet can be added manually here, for example:

// packages.add(new MyReactNativePackage());

packages.add(new RNZhugeioPackage());

return packages;

}

}

若是私有部署的用户,需要更改数据上传地址,请将上述onCreate()里的代码更改为:

@Override

public void onCreate(){

Super.onCreate();

...

//设置上传地址,普通用户请勿更改。必须在调用init之前设置

ZhugeSDK.getInstance().setUploadURL("https://www.zhugeio.com",null)

//ZhugeSDK初始化

ZhugeSDK.getInstance().init(this,"yourAppKey","youAppChannel");

...

}

2.3. 使用说明

导入Zhugeio

import Zhugeio from 'react-native-plugin-zhugeio'

track 追踪事件

Zhugeio.track('事件名称',{'属性1':'值1','属性2':'值2'});

自定义时长事件

使用startTrack()开始一个事件的统计

Zhugeio.startTrack('事件名称');

使用相同的事件名称结束事件统计

Zhugeio.endTrack('事件名称',{'属性1':'值1'});

startTrack()与endTrack()需成对出现,单独使用没有效果。

识别用户

使用identify()识别用户

Zhugeio.identify('用户ID',{'用户属性':'用户值'})

收入数据采集

使用trackRevenue函数,自动记录收入事件及事件属性

zhuge.trackRevenue({

'price': 229,

'productID':'小米NFC手环',

'productQuantity':2,

'revenueType':'手环'

});

实时调试

Zhugeio.openDebug();

日志输出

该方法仅对Android平台可用,iOS平台请参阅 iOS集成文档

Zhugeio.openLog();

©zhugeio.com 京ICP备15049545号            文档更新时间 2021-05-11 17:36:19

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值