【React Native开发】React Native移植原生Android项目

转载请标明出处:

http://blog.csdn.net/developer_jiangqq/article/details/50519677

本文出自:【江清清的博客】

(一)前言

【好消息】个人网站已经上线运行,后面博客以及技术干货等精彩文章会同步更新,请大家关注收藏:http://www.lcode.org

前三节课程我们已经对于React Native For Android的环境搭建,IDE安装配置以及应用运行,调试相关的知识点做了讲解。今天我们来讲一个非常有用的知识点。移植我们已有的原生Android项目到React Native中。

刚创建的React Native技术交流群(282693535),欢迎各位大牛,React Native技术爱好者加入交流!同时博客左侧欢迎微信扫描关注订阅号,移动技术干货,精彩文章技术推送!

在React Native中React其实更多关注的是视图View层。所以React Native本身也支持并且可以让我们非常简单方便的移植一个Android原生的项目到React Native中。

(二)前提准备工作

①.首先我们有一个采用Gradle构建的Android应用项目,这个大家直接采用Android Studio进行创建一个项目即可。我这边新建一个目录TestHello,然后采用Android Studio创建一个android项目在该文件夹下面。具体如下:

②.电脑必须安装Node.js,具体安装使用方法(点击进入)

(三)Android项目相关配置

2.1 在我们Android项目的build.gradle中添加React Native依赖,然后同步,具体代码如下:

compile ‘com.facebook.react:react-native:0.17.+‘

[注意].该会同步0.17版本以上的react native,官方的版本还是停留在0.13没有更新,我本地的reactnative是0.17版本的,所以大家这边配置一定要跟自己本地的版本保持一致或者更新。关于这个问题今天我下午研究了一下去,踩了很多坑啊~~ 不过ReactNative中文网那边我已经让站长更新了版本。

2.2紧接着我们需要在项目AndroidManifest.xml中加入网络访问权限

<uses-permission android:name="android.permission.INTERNET" />

该仅仅用于开发阶段从开发服务器加载最细的JavaScript代码,在正式发布版本中,如果有需要可以把该网络权限删掉。

(四)添加原生代码

在Android项目的MainActivity中,我们需要配置相关代码来进行启动运行React Native库。我们需要创建ReactRootView,然后在里边渲染React引用,并且设置成Activity的主视图即可。

具体代码如下:

public class MainActivity extends Activity implements DefaultHardwareBackBtnHandler {
    privateReactRootView mReactRootView;
    privateReactInstanceManager mReactInstanceManager;

    @Override
    protectedvoid 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, "TestHello",null);

       setContentView(mReactRootView);
    }

    @Override
    publicvoid invokeDefaultOnBackPressed() {
       super.onBackPressed();
    }
}

注意以下的代码:

mReactRootView.startReactApplication(mReactInstanceManager,"TestHello", null);

以上其中方法第二种个参数我这边采用TestHello来进行命名了,注意这个要和后面讲到的东西进行统一,具体我们继续往下看。

在React Native中,其实FB给我们提供了ReactInstanceManger来替我们管理Activity相关的生命周期,所以我们需要传递一些Actitivty相关的生命周期到ReactInstanceManger中。具体代码onPause()和onResume()方法如下:

@Override
    protectedvoid onPause() {
       super.onPause();

        if(mReactInstanceManager != null) {
           mReactInstanceManager.onPause();
        }
    }
    @Override
    protectedvoid onResume() {
       super.onResume();

        if(mReactInstanceManager != null) {
            mReactInstanceManager.onResume(this,this);
        }
    }

紧接着对于返回按钮键的事件我们也需要传递一下:

@Override
 public void onBackPressed() {
    if(mReactInstanceManager != null) {
       mReactInstanceManager.onBackPressed();
    } else {
       super.onBackPressed();
    }
}

这样我们就可以当用户按下返回键的时候,javaScript代码可以做相关处理。当然如果前端不处理响应的事件,那么会回调到上面的invokeDefaultOnBackPressed()方法中。继而回退事件转移到Activity了,下面就是Activity该怎么样执行,就怎么样执行了。默认事件就是关闭Activity了

最后一步就是需要处理一下设备菜单了,默认情况下我们可以摇晃一下手机来弹出菜单,但是对于模拟器,该方法就不适用了,所以我们才拦截事件方法进行相关处理一下即可。

@Override
public boolean onKeyUp(int keyCode, KeyEvent event){
    if(keyCode == KeyEvent.KEYCODE_MENU && mReactInstanceManager != null) {
       mReactInstanceManager.showDevOptionsDialog();
       return true;
    }
    return super.onKeyUp(keyCode, event);
}

到此为止我们的Android项目Activity和配置文件以及完成了最基本的配置方法了。

(五)添加js

下面我们采用命令行,首先切换到项目的根目录上面(我的例子是切换到TestHello目录下)

5.1.命令行运行npm init 运行截图如下:

该命令会创建一个package.json文件,并且提示我们输入一些信息,默认不输入即可,不过name必须要为全英文小写哦,具体结果执行结果如下:

5.2.命令行运行npm install  --save react-native  进行安装react native模块以及相关node模块,运行截图如下:

这里开始安装node模块以及react native模块,具体运行结果会生成node_module文件夹如下:

5.3.最后运行如下命令即可:

curl -o .flowconfig  https://raw.githubusercontent.com/facebook/react-native/master/.flowconfig

做一下flow配置

以上三步全部完成了,上面给我们创建node模块,然后添加了react-native npm依赖。接下来我们需要修改package.json文件,在scripts标签那边添加如下代码:

"start":"node_modules/react-native/packager/packager.sh"

具体修改截图如下:

5.4.现在我们创建一下文件命名为:index.android.js,然后在里边添加如下代码:

‘use strict‘;
var React = require(‘react-native‘);
var {
  Text,
  View
} = React;

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

React.AppRegistry.registerComponent(‘TestHello‘, ()=> TestHello);

以上就完成了所有的相关代码以及react-native配置了,注意上面的都采用TestHello了,希望大家都用一样的名字和前面MainActivity进行统一哦。

(六)运行APP

上面的配置步骤全部完成了,下面我们要运行APP了,首先我们需要开启开发服务器,使用如下命令即可:

npm start

运行结果如下:

接下来就是最后一步了,直接运行react-native run-android命令编译运行应用就可以了,运行结果如下:

这样就完成了一个简单的Android原生项目移植到ReactNative中了。

(七)最后总结

今天移植Android原生项目移植到React Native中,期间也遇到了很多问题,例如因为官网的文档没有保持最新,后来经过排查采坑才发现。大家有问题可以加一下群React Native技术交流群(282693535)或者底下进行回复一下。

尊重原创,转载请注明:From Sky丶清(http://blog.csdn.net/developer_jiangqq) 侵权必究!

关注我的订阅号(codedev123),每天分享移动开发技术(Android/IOS),项目管理以及博客文章!(欢迎关注,第一时间推送精彩文章)

关注我的微博,可以获得更多精彩内容

时间: 2024-10-25 10:40:00

【React Native开发】React Native移植原生Android项目的相关文章

React Native—集成到原生Android项目

目前的react-native版本是0.57.8,參考了一些文章之後,終於集成好了.React Native環境的搭建我就不説了,詳細的可以參考React Native中文網的搭建文檔. 創建新的Android工程 環境配置好之後(sdk下載可能比較慢),用Android Studio創建一個Empty Activity的項目. 集成React Native 安裝相關依賴 在項目根目錄下執行 npm init 命令,生成 package.json 文件.此時要注意一下package name和入

【转】【React Native开发】

[React Native开发]React Native控件之ListView组件讲解以及最齐全实例(19) [React Native开发]React Native控件之Touchable*系列组件详解(18) [React Native开发]React Native控件之ViewPagerAndroid讲解以及美团首页顶部效果实例(17) [React Native开发]React Native控件之Switch开关与Picker选择器组件讲解以及使用(16) [React Native开发

【React Native开发】React Native进行签名打包成Apk

转载请标明出处: http://blog.csdn.net/developer_jiangqq/article/details/50525976 本文出自:[江清清的博客] (一)前言 [好消息]个人网站已经上线运行,后面博客以及技术干货等精彩文章会同步更新,请大家关注收藏:http://www.lcode.org 前几节课程我们对于React Native的一些基础配置,开发工具以及调试,Android项目移植做了相关讲解,今天一起来学习一下另外一个比较重要的知识点,就是React Nativ

React Native与React的关系及特点

一.React.React.js和React Native的关系 React是基础框架,是一套基础设计实现理念,开发者不能直接使用它来开发移动应用或网页. 在React之上发展出了React.js框架用来开发网页,发展出来React Native用来开发移动应用. 因为React基础框架与React.js框架是同时出现.同时进化发展的,就造成了React基础框架的基本概念.设计思想都是在React.js的相关文档中描述的. 后来,Facebook推出React Native后,也没有把React

【React Native开发】React Native For Android环境配置以及第一个实例

转载请标明出处: http://blog.csdn.net/developer_jiangqq/article/details/50456967 本文出自:[江清清的博客] (一)前言 FaceBook早期开源发布了React Native For IOS,终于在2015年9月15日也发布了ReactNative for Android,虽然Android版本的项目发布比较迟,但是也没有阻挡了广大开发者的热情.可以这样讲在2015年移动平台市场上有两个方向技术研究比较火,第一种为阿里,百度,腾讯

React—Native开发之原生模块向JavaScript发送事件

首先,由RN中文网关于原生模块(Android)的介绍可以看到,RN前端与原生模块之 间通信,主要有三种方法: (1)使用回调函数Callback,它提供了一个函数来把返回值传回给JavaScript. (2)使用Promise来实现. (3)原生模块向JavaScript发送事件. 其中,在我的博客React-Native开发之原生模块封装(Android)升级版 较为详细的阐述了如何使用回调函数Callback 来将数据传向JavaScript 端. 但是有一个比较难以解决的问题是: cal

Android React Native 开发环境搭建---windows下

环境搭建 环境搭建可以参考RN官网,也可以参考中文版本:http://reactnative.cn/docs/0.45/getting-started.html 如果你希望可以看到原版的安装流程,可以看官方的地址,本文只是我个人的实践,并且仅限于window平台. 官方的地址:https://facebook.github.io/react-native/docs/getting-started.html 1.下载Chocolatey 去官网下载,一般没有问题. 2.Node,python2,j

React Native 技术 开发跨平台 Native App 初探

转载请注明出处:http://blog.csdn.net/smartbetter/article/details/64190798 我们已经了解像 Titanium 和 PhoneGap 等框架,它们能让开发者用 Web 技术构建移动应用.这是一个优势,支持开发者使用原先网络和移动开发的相关技术.仅如此,相同的代码库经过小幅度的修改便能适用多个平台--这就是著名的一次编写,到处运行.然而,当涉及到构建应用的性能时,这些框架的缺点显露无遗,尽管它们有一些吸引力,但却一直更适用于构建原生应用.Rea

React Native:使用 JavaScript 构建原生应用 详细剖析

数月前,Facebook 对外宣布了正在开发的 React Native 框架,这个框架允许你使用 JavaScript 开发原生的 iOS 应用——就在今天,Beta 版的仓库释出了! 基于 PhoneGap 使用 JavaScript 和 HTML5 开发 iOS 应用已经有好几年了,那 React Native 有什么牛的? React Native 真的很牛,让大家兴奋异常的主要原因有两点: 可以基于 React Native使用 JavaScript 编写应用逻辑,UI 则可以保持全是