react-native 與 java 混合開發(fā) 1/3 框架搭建

有哪些場景是需要混合開發(fā)呢驳糯?

  1. react-native 原生android的UI的支持
  2. react-native 的一些交互邏輯需要java處理(比如APP跳轉(zhuǎn)微信小程序)

根據(jù) 單一職責(zé)的原則 腿宰,文章分為三篇梅掠,此篇為react-native 與 java 混合開發(fā) 1/3 框架搭建

關(guān)鍵
關(guān)鍵是js與java的通信

搭建步驟

一. 新建一個(gè)react-native項(xiàng)目和android項(xiàng)目居暖。

  1. 新建一個(gè)react-native 項(xiàng)目
  2. 在新建的react-native 項(xiàng)目的根目錄建立新的文件夾android
  3. 在android目錄下用android studio 建立新的android項(xiàng)目

二. 將新建的兩個(gè)項(xiàng)目聯(lián)系起來
1.在Android Studio中左面菜單欄中選擇Android(默認(rèn)也是這個(gè))究驴,
2.在build.gradle(Project: xxx)中的修改allprojects如下:

allprojects {
    repositories {
        google()
        jcenter()
        maven {
            // All of React Native (JS, Android binaries) is installed from npm
            url "$rootDir/../node_modules/react-native/android"
        }
    }
}

3.在build.gradle(Module: app)中的dependencies添加

  implementation "com.facebook.react:react-native:+"

三.使用原生調(diào)用我們的JS組件
1.在react-native 的根目錄下新建index.js文件苍蔬,做為的react-native界面的入口文件. 下面代碼中的HelloWorld組件是一個(gè)事例惰蜜,大家自行更換。

import React from 'react';
import {AppRegistry, StyleSheet, Text, View} from 'react-native';

class HelloWorld extends React.Component {
  render() {
    return (
      <View style={styles.container}>
        <Text style={styles.hello}>Hello, World</Text>
      </View>
    );
  }
}
var styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
  },
  hello: {
    fontSize: 20,
    textAlign: 'center',
    margin: 10,
  },
});

AppRegistry.registerComponent('MyReactNativeApp', () => HelloWorld);

上面代碼的 MyReactNativeApp 是react-native告訴原生android的名稱

2.在原生中新建一個(gè)Activity渲染react-native組件.

import com.facebook.react.ReactInstanceManager;
import com.facebook.react.ReactRootView;
import com.facebook.react.common.LifecycleState;
import com.facebook.react.modules.core.DefaultHardwareBackBtnHandler;
import com.facebook.react.shell.MainReactPackage;


public class MyReactActivity extends Activity implements DefaultHardwareBackBtnHandler {
    private ReactRootView mReactRootView;
    private ReactInstanceManager mReactInstanceManager;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        mReactRootView = new ReactRootView(this);
        mReactInstanceManager = ReactInstanceManager.builder()
                .setApplication(getApplication())
                .setBundleAssetName("index.android.bundle")
                .setJSMainModulePath("index")
                .addPackage(new MainReactPackage())
                .setUseDeveloperSupport(BuildConfig.DEBUG)
                .setInitialLifecycleState(LifecycleState.RESUMED)
                .build();
        mReactRootView.startReactApplication(mReactInstanceManager, "MyReactNativeApp", null);

        setContentView(mReactRootView);
    }

    @Override
    public void invokeDefaultOnBackPressed() {
        super.onBackPressed();
    }
}

3.在AndroidManifest.xml中添加activity的聲明

<activity
  android:name=".MyReactActivity"
  android:label="@string/app_name"
  android:theme="@style/Theme.AppCompat.Light.NoActionBar">
</activity>

四.配置權(quán)限
1.在manifests文件夾下的AndroidManifest.xml下添加權(quán)限

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鞭缭,一起剝皮案震驚了整個(gè)濱河市剖膳,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌岭辣,老刑警劉巖吱晒,帶你破解...
    沈念sama閱讀 221,331評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異沦童,居然都是意外死亡仑濒,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,372評論 3 398
  • 文/潘曉璐 我一進(jìn)店門偷遗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來墩瞳,“玉大人,你說我怎么就攤上這事氏豌『碜茫” “怎么了?”我有些...
    開封第一講書人閱讀 167,755評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長泪电。 經(jīng)常有香客問我般妙,道長,這世上最難降的妖魔是什么相速? 我笑而不...
    開封第一講書人閱讀 59,528評論 1 296
  • 正文 為了忘掉前任碟渺,我火速辦了婚禮,結(jié)果婚禮上突诬,老公的妹妹穿的比我還像新娘止状。我一直安慰自己,他們只是感情好攒霹,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,526評論 6 397
  • 文/花漫 我一把揭開白布怯疤。 她就那樣靜靜地躺著,像睡著了一般催束。 火紅的嫁衣襯著肌膚如雪集峦。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,166評論 1 308
  • 那天抠刺,我揣著相機(jī)與錄音塔淤,去河邊找鬼。 笑死速妖,一個(gè)胖子當(dāng)著我的面吹牛高蜂,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播罕容,決...
    沈念sama閱讀 40,768評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼备恤,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了锦秒?” 一聲冷哼從身側(cè)響起露泊,我...
    開封第一講書人閱讀 39,664評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎旅择,沒想到半個(gè)月后惭笑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,205評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡生真,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,290評論 3 340
  • 正文 我和宋清朗相戀三年沉噩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片柱蟀。...
    茶點(diǎn)故事閱讀 40,435評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡川蒙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出产弹,到底是詐尸還是另有隱情派歌,我是刑警寧澤,帶...
    沈念sama閱讀 36,126評論 5 349
  • 正文 年R本政府宣布痰哨,位于F島的核電站胶果,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏斤斧。R本人自食惡果不足惜早抠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,804評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望撬讽。 院中可真熱鬧蕊连,春花似錦、人聲如沸游昼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,276評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽烘豌。三九已至载庭,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間廊佩,已是汗流浹背囚聚。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留标锄,地道東北人顽铸。 一個(gè)月前我還...
    沈念sama閱讀 48,818評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像料皇,于是被迫代替她去往敵國和親谓松。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,442評論 2 359

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