React Native 的友盟集成

前言

最近從iOS開發(fā)轉(zhuǎn)到RN開發(fā), 碰到許多坑, 想記錄下來鞏固學習. 希望本文能幫到你~~

免費獲得:

  • SDK下載及文檔
  • 安卓集成指南
  • iOS集成指南

SDK下載及文檔

SDK地址: 官方下載 (記得關(guān)VPN訪問友盟官網(wǎng)喲~)
文檔地址: 偷看一下

安卓集成指南

未接觸過安卓開發(fā)的, 看到文檔的時候一定頭很大. 沒事我來帶大家一步一步趟過去.

1.檢查SDK文件

我們SDK下載下來后看到的文件夾, 包括Android和ReactNative部分.Android里放的是jar文件, ReactNative里放的是java文件. 參考如下:


圖1
圖2

2.放jar文件

這個最簡單! 放進工程目錄的libs文件夾下, 搞定~ 路徑如下:


圖3

2-1添加依賴

我們先到android/app/build.gradle


圖4

找到dependencies, 添加架包(有兩種方式,自己搭配啦~):

1.通用:
dependencies {
    compile fileTree(include: ['*.jar'], dir: 'libs')
2.每個都添加一次:
dependencies {
    compile files('libs/umeng-analytics-7.5.3.jar')
    compile files('libs/umeng-common-1.5.3.jar')

2-2查看權(quán)限配置

到android/app/src/main/AndroidMainifest.xml


圖5

配置好權(quán)限, 當然你可以參考官方demo, 選擇其他權(quán)限獲取更精準的數(shù)據(jù)啦~

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE"/>

3. 放java文件

文檔沒寫路徑, 只寫了文件引用. 超超找了路徑給你們~ 如下:


圖6

這里不要直接抄demo, 要放在包名路徑下.
比如你的包名是com.umeng, 那么可以在java/com/umeng/里建個'invokenative'放java文件, 如下:


圖7

剩下的就是根據(jù)警告, 修正引用路徑~

4.引用問題

如果之前沒開發(fā)安卓的經(jīng)驗, 這里要注意'引用路徑'的問題:
所有demo中引用的路徑一定不能照抄demo的如:
import com.umeng.soexample.invokenative.RNUMConfigure;
如果你的路徑是com/umeng/invokenative, 那要改成:
import com.umeng.invokenative.RNUMConfigure;

5.初始化

5-1MainActivity中初始化

代碼如下:

public class MainActivity extends ReactActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //ShareModule.initSocialSDK(this);
        //PushModule.initPushSDK(this);
        MobclickAgent.setSessionContinueMillis(1000);
        MobclickAgent.setScenarioType(this, EScenarioType.E_DUM_NORMAL);
        MobclickAgent.openActivityDurationTrack(false);
        //PushAgent.getInstance(this).onAppStart();
    }


    @Override
    public void onResume() {
        super.onResume();
        MobclickAgent.onResume(this);
    }
    @Override
    protected void onPause() {
        super.onPause();
        MobclickAgent.onPause(this);
    }

5-2MainApplication中初始化

代碼如下:

 @Override
        protected List<ReactPackage> getPackages() {
            return Arrays.<ReactPackage>asList(
                new MainReactPackage(),
                new DplusReactPackage()
            );
        }
    };


    @Override
    public void onCreate() {
        super.onCreate();
        SoLoader.init(this, /* native exopackage */ false);
        UMConfigure.setLogEnabled(true);
        //初始化組件化基礎(chǔ)庫, 統(tǒng)計SDK/推送SDK/分享SDK都必須調(diào)用此初始化接口
        RNUMConfigure.init(this, "59892f08310c9307b60023d0", "Umeng", UMConfigure.DEVICE_TYPE_PHONE,
            "669c30a9584623e70e8cd01b0381dcb4");
        //initUpush();

    }

注意:未集成推送功能, secret參數(shù)可以傳空字符串"".

iOS集成指南:

跟安卓一樣, iOS有單獨的文件夾, 放著對應的framework, 我們只要打開工程, 學著demo做:

1.引用framework和橋接文件

  • 找到framework如下:


    圖8
  • 找到2個必要的橋接文件


    圖9
圖10

為了以后統(tǒng)一管理, 把framework放到UMComponents文件夾里, 把橋接文件放到文件夾UMReactBridge文件夾.
再把這兩個文件夾用鼠標拖到工程中. 如下圖:


圖11

接下來按照demo里初始化代碼如下:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
  [UMConfigure setLogEnabled:NO];
  [RNUMConfigure initWithAppkey:@"我的appkey" channel:@"App Store"];
  
  [MobClick setScenarioType:E_UM_NORMAL];
  [MobClick setCrashReportEnabled:YES];

到這里iOS友盟就集成完畢了~~

2.魔性BUG

注意: demo寫了 [UMessage addLaunchMessage]; 記得刪掉哦! 不然app會有魔性的啟動屏哦~ 感興趣的小伙伴可以自己玩玩看~
到此, 友盟的集成完畢!
如果小伙伴們有埋點的需求的可以參考文章:React Native 友盟統(tǒng)計--打點/埋點

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末出皇,一起剝皮案震驚了整個濱河市关划,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌遍膜,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機憾赁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來散吵,“玉大人龙考,你說我怎么就攤上這事》溃” “怎么了晦款?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長枚冗。 經(jīng)常有香客問我缓溅,道長,這世上最難降的妖魔是什么赁温? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任坛怪,我火速辦了婚禮,結(jié)果婚禮上股囊,老公的妹妹穿的比我還像新娘袜匿。我一直安慰自己,他們只是感情好稚疹,可當我...
    茶點故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布居灯。 她就那樣靜靜地躺著,像睡著了一般内狗。 火紅的嫁衣襯著肌膚如雪怪嫌。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天柳沙,我揣著相機與錄音岩灭,去河邊找鬼。 笑死赂鲤,一個胖子當著我的面吹牛噪径,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蛤袒,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼熄云,長吁一口氣:“原來是場噩夢啊……” “哼膨更!你這毒婦竟也來了妙真?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤荚守,失蹤者是張志新(化名)和其女友劉穎珍德,沒想到半個月后练般,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡锈候,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年薄料,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片泵琳。...
    茶點故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡摄职,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出获列,到底是詐尸還是另有隱情谷市,我是刑警寧澤,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布击孩,位于F島的核電站迫悠,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏巩梢。R本人自食惡果不足惜创泄,卻給世界環(huán)境...
    茶點故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望括蝠。 院中可真熱鬧鞠抑,春花似錦、人聲如沸忌警。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽慨蓝。三九已至感混,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間礼烈,已是汗流浹背弧满。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留此熬,地道東北人庭呜。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像犀忱,于是被迫代替她去往敵國和親募谎。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,629評論 2 354

推薦閱讀更多精彩內(nèi)容