开发者社区> 问答> 正文

[@炯轩][¥20]如何将React Native集成至Android原生应用?

如何将React Native集成至Android原生应用?

展开
收起
黄二刀 2018-12-16 21:07:59 2480 0
2 条回答
写回答
取消 提交回答
  • 步骤:

    在appbuild.gradle的dependencies标签下添加: compile "com.facebook.react:react-native:+";
    在appbuild.gradle的android标签下添加: configurations.all { resolutionStrategy.force 'com.google.code.findbugs:jsr305:+' }
    在appbuild.gradle的androiddefaultConfig标签下添加: ndk { abiFilters "armeabi-v7a", "x86" }
    在build.gradle的allprojectsrepositories标签下添加: maven { url "$rootDir/reactnative/node_modules/react-native/android" }
    在gradle.properties内添加: android.useDeprecatedNdk=true

    创建一个activity文件RNActivity:
    public class RNActivity extends ReactActivity {

    @Nullable
    @Override
    protected String getMainComponentName() {
        return "demo1031";
    }

    }

    创建一个Application文件RNApplication:
    public class RNApplication extends Application implements ReactApplication {

    private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {
        @Override
        public boolean getUseDeveloperSupport() {
            return BuildConfig.DEBUG;
        }
    
        @Override
        protected List<ReactPackage> getPackages() {
            return Arrays.<ReactPackage>asList(
                    new MainReactPackage()
            );
        }
    
    };
    
    @Override
    public ReactNativeHost getReactNativeHost() {
        return mReactNativeHost;
    }
    
    @Override
    public void onCreate() {
        super.onCreate();
        SoLoader.init(this,false);
    }

    }

    在AndroidManifest.xml内指定application路径android:name=".RNApplication"

    在项目目录下创建reactnative文件夹, 在reactnative文件夹创建package.json文件:
    {

    "name": "reactnative",
    "version": "0.0.1",
    "private": true,
    "scripts": {
        "start": "node node_modules/react-native/local-cli/cli.js start",
        "test": "jest"
    },
    "dependencies": {
        "react": "16.0.0-beta.5",
        "react-native": "0.49.5"
    },
    "devDependencies": {
        "babel-jest": "21.2.0",
        "babel-preset-react-native": "4.0.0",
        "jest": "21.2.1",
        "react-test-renderer": "16.0.0-beta.5"
    },
    "jest": {
        "preset": "react-native"
    }

    }

    在reactnative文件夹创建index.android.js文件:
    import React, { Component } from 'react';
    import {
    AppRegistry,
    StyleSheet,
    Text,
    View,
    Button
    } from 'react-native';

    export default class Index extends Component {
    _onPress() {

    alert("我是react-native弹窗");

    }

    render() {

    return (
      <View style={styles.container}>
        <Button title="Button" color="#ff8500" onPress={()=> this._onPress()}/>
      </View>
    );

    }
    }

    const styles = StyleSheet.create({
    container: {

    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',

    },
    });

    AppRegistry.registerComponent('reactnative', () => Index);

    在项目目录文件夹reactnative下执行命令npm i, 然后再npm start
    使用Android studio运行项目, ok, 收工!

    假如报错: Unable to load script from assets 'index.android.bundle'..., 可以在项目main文件夹下新建文件夹assets, 然后在reactnative下运行命令: react-native bundle --platform android --dev false --entry-file index.android.js --bundle-output ../app/src/main/assets/index.android.bundle --assets-dest ../app/src/main/res/

    作者:hello老文
    链接:https://www.jianshu.com/p/68940f43e557
    來源:简书
    简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

    2019-07-17 23:22:28
    赞同 展开评论 打赏
  • Android工程内接入RN的SDK就可以,官网有文档的啊。

    2019-07-17 23:22:27
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
58同城Android客户端Walle框架演进与实践之路 立即下载
Android组件化实现 立即下载
蚂蚁聚宝Android秒级编译——Freeline 立即下载