返回顶部
首页 > 资讯 > 移动开发 >Android原生嵌入React Native详解
  • 615
分享到

Android原生嵌入React Native详解

nativeReactAndroid 2022-06-06 07:06:32 615人浏览 独家记忆
摘要

1.首先集成的项目目录 我使用的是直接按照React-native init Project 的格式来导入的,也就是说,我的Android项目目

1.首先集成的项目目录

我使用的是直接按照React-native init Project 的格式来导入的,也就是说,我的Android项目目录是跟node_modules是在一个目录下的。

我们init完项目之后,项目初始化完成了,这时候我们可以用命令react-native run-android直接运行项目,至于怎么调试,之前已经说过。

说一下我们怎么开发和运行分开吧,我们开发一般会选择WEBstrom,开发后我们会Android和iOS的编译分开。



启动npm

下面说一下android 嵌入RN环境吧。

编写Android原生代码,用来调用RN


package com.reactdemo;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.KeyEvent;
import com.facebook.react.LifecycleState;
import com.facebook.react.ReactInstanceManager;
import com.facebook.react.ReactRootView;
import com.facebook.react.modules.core.DefaultHardwareBackBtnHandler;
import com.facebook.react.shell.MainReactPackage;
public class MainActivity extends AppCompatActivity implements DefaultHardwareBackBtnHandler {
 private ReactInstanceManager mReactInstanceManager;
 private ReactRootView mReactRootView;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  mReactRootView = new ReactRootView(this);
  mReactInstanceManager = ReactInstanceManager.builder()
    .setApplication(getApplication())
    .setBundleAssetName("index.android.bundle")
    .setjsMainModuleName("index.android")
    .addPackage(new MainReactPackage())
    .setUseDeveloperSupport(BuildConfig.DEBUG)
    .setInitialLifecycleState(LifecycleState.RESUMED)
    .build();
  mReactRootView.startReactApplication(mReactInstanceManager, "ReactDemo", null);
  setContentView(mReactRootView);
 }
 @Override
 public boolean onKeyUp(int keyCode, KeyEvent event) {
  if (keyCode == KeyEvent.KEYCODE_MENU && mReactInstanceManager != null) {
   mReactInstanceManager.showDevOptionsDialog();
   return true;
  }
  return super.onKeyUp(keyCode, event);
 }
 @Override
 public void onBackPressed() {
  if (mReactInstanceManager != null) {
   mReactInstanceManager.onBackPressed();
  } else {
   super.onBackPressed();
  }
 }
 @Override
 public void invokeDefaultOnBackPressed() {
  super.onBackPressed();
 }
 @Override
 protected void onPause() {
  super.onPause();
  if (mReactInstanceManager != null) {
   mReactInstanceManager.onHostPause();
  }
 }
 @Override
 protected void onResume() {
  super.onResume();
  if (mReactInstanceManager != null) {
   mReactInstanceManager.onHostResume(this, this);
  }
 }
}

注意要加上网络等一些权限。

创建package.JSON,添加react native包

使用命令npm init,跟着步骤走就好了,给大家截个图:


最后你就可以在你的RN项目里面看到一个package.json。


运行Demo

注:可能会出现java.lang.RuntimeException: Could not get BatchedBridge, make sure your bundle is packaged correctly这个错误,react-native bundle —platfORM android —dev false —entry-file index.android.js —bundle-output ReactDemo/app/src/main/assets/index.android.bundle —sourcemap-outpu ReactDemo/app/src/main/assets/index.android.map —assets-dest ReactDemo/app/src/main/res/

您可能感兴趣的文章:Android原生项目集成React Native的方法react-native 封装选择弹出框示例(试用ios&android)windows下React Native的Android环境部署及布局示例Android React Native原生模块与JS模块通信的方法总结Android Rreact Native 常见错误总结如何在原有Android项目中快速集成React Native详解


--结束END--

本文标题: Android原生嵌入React Native详解

本文链接: https://lsjlt.com/news/23813.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作