史上最详细的Android原生APP中添加ReactNative进行混合开发教程

背景

React Native出来已经一段时间了,相对来说也算稳定了,在很多的企业中都实际使用他们,混合开发已经是未来的一种趋势,混合开发中使用的技术很多,不外乎Html5、JS框架通过一定的技术和原始交互,目前主流混合开发React Native、Cordova、APICloud、MUI、AppCan、Sencha Touch、jQuery Mobile等等(其他的小伙伴们自己收集),目前网上写教程的人很多,但是React Native更新速度很快,根据他们的教程,中间会遇到各种问题,今天我和大家一起踩踩各种坑,让小伙伴们快速集成到自己的APP中。

集成的小伙伴一定要注意图片中标注和备注哦,不然有可能会走弯路哦

集成步骤

参考官方文档->react native 文档

本文使用开发环境 Android studio

注意最新的React Native支持的最新的SDK为16(android4.1)

npm环境,小伙伴们自己安装 nodeJS自己安装,可以参考官方文档安装环境,有问题可以发411437734@qq.com沟通

创建Android项目(已有项目跳过)

1.打开Android studio  

2.输入项目名称,选择项目目录,点击next  

   

   

   

至此项目创建完成(需要注意的是最新的React Native支持最新SDK版本为16 android4.1)

React Native集成到上面我们创建的ReactNativeAPPDemo中

参考Facebook react native文档

1.进入项目根目录,添加JS到项目中-点击Android studio中的Terminal(如下图)  

分别执行一下语句


  1. npm init 
  2. npm install --save react react-native 
  3. curl -o .flowconfig https://raw.githubusercontent.com/facebook/react-native/master/.flowconfig  

init 主要根据提醒生成package.json文件

install --save react react-native 安装React 和React Native

curl -o .flowconfig https://raw.githubusercontent.com/facebook/react-native/master/.flowconfig 下载.flowconfig文件

参考图片  

查看项目中有node_modules,说明react和react native 安装完成  

在项目根目录添加.flowconfig

参考下图  

也可以手动创建在浏览器打开https://raw.githubusercontent.com/facebook/react-native/master/.flowconfig网址复制内容创建文件  

ReactNativeAppDemo配置相关内容

1.添加"start": "node node_modules/react-native/local-cli/cli.js start" 到package.json 文件下 scripts标签 修改前  

修改后  

2.添加index.android.js文件到项目中  

 


  1. 'use strict'; import React from 'react'; import { 
  2.   AppRegistry, 
  3.   StyleSheet, 
  4.   Text, 
  5.   View 
  6. } from 'react-native'; class HelloWorld extends React.Component { 
  7.   render() {     return (       <View style={styles.container}> 
  8.         <Text style={styles.hello}>Hello, World</Text> 
  9.       </View> 
  10.     ) 
  11.   } 
  12. } var styles = StyleSheet.create({ 
  13.   container: { 
  14.     flex: 1, 
  15.     justifyContent: 'center', 
  16.   }, 
  17.   hello: { 
  18.     fontSize: 20, 
  19.     textAlign: 'center', 
  20.     margin: 10, 
  21.   }, 
  22. }); 
  23. AppRegistry.registerComponent('HelloWorld', () => HelloWorld);  

至此React native配置基本完成

3.App build.gradle配置


  1. dependencies { 
  2. ... 
  3. compile "com.facebook.react:react-native:+" // From node_modules.}  

这里注意不要使用maven中的,因为我们使用的是我们本地node_modules中的,注意最新版本中支持的是23,appcompat-v7:23.0.1,暂时没有试24的api  

整个工程build.gradle配置


  1. allprojects { 
  2. repositories { 
  3.     ... 
  4.     maven {         // All of React Native (JS, Android binaries) is installed from npm 
  5.         url "$rootDir/node_modules/react-native/android" 
  6.     } 
  7. ... 
  8. }    

添加<uses-permission android:name="android.permission.INTERNET" />到AndroidManifest.xml:

确定External Libraries  

   

确定是下是最新的,例如确定是0.34.1而不是0.20.1,如果出现请检查


  1. maven { 
  2.            `url "$rootDir/../node_modules/react-native/android"`//地址是否正确 
  3.        }  
  4. 修改url "$rootDir*/..*/node_modules/react-native/android"为url "$rootDir/node_modules/react-native/android"  

添加native code

官方给出的  

到时最新版本中提供了更加简单的方式,没错就是继承。  

在这里我们也需要自定义一个Application否则 运行时会报错,不信的小伙伴可以试一试  

   

到此为止,ReactNative 集成到已有项目中完成!!!迫不及待的运行试试吧!!  

在Terminal中运行 npm start,看到下图表示启动成功  

运行以后发现如下错误  

react-native报错:Could not get BatchedBridge, make sure your bundle is packaged correctly

莫紧张,这是因为bundle没有打包好。找不到编译打包后的js文件。其实就是android studio默认的寻找js文件地址和react-native自己的工具编译所使用的地址不同。

解决方法

方法一

进入项目,在android/app/src/main下新建assets目录。执行以下命令


  1. $> react-native start > /dev/null 2>&1 &   
  2. $> curl "http://localhost:8081/index.android.bundle?platform=android" -o 
  3. > "app/src/main/assets/index.android.bundle"  

在项目根目录下执行


  1. <!--$> (cd android/ && ./gradlew assembleDebug)-->$> (cd 项目名称/ && ./gradlew assembleDebug) 

把创建的apk安装到android设备

方法二

进入项目,在android/app/src/main下新建assets目录

启动服务器


  1. $>react-native start 
  2. $>react-native bundle --platform android --dev false --entry-file index.android.js --bundl  

在assets文件夹下会生成index.android.bundle文件,把创建的apk文件安装到android设备

方法三

进入项目,在android/app/src/main下新建assets目录

在package.json中配置下面代码


  1. "scripts": { 
  2.     "start": "node node_modules/react-native/local-cli/cli.js start", 
  3.     "bundle-android": "react-native bundle --platform android --dev false --entry-file index.android.js --bundle-output app/src/main/assets/index.android.bundle --sourcemap-output app/src/main/assets/index.android.map --assets-dest android/app/src/main/res/" 
  4.   }, 

个人推荐使用方法三,方法三解决不了推荐方法二 手动执行

修改刚刚的package.json文件 

如果真机(模拟器)需要执行


  1. adb reverse tcp:8081 tcp:8081 

一定要确定连接网络哦!!

 

开心的进行开发吧!

其他可能遇到的问题

ReactNative兼容64位Android手机

libgnustl_shared.so" is 32-bit instead of 64-bit类似错误

解决方法

  1. 在项目的根目录的 gradle.properties 里面添加一行android.useDeprecatedNdk=true.
  2. 在 build.gradle 文件里添加以下代码

  1.  android { 
  2. ... 
  3. defaultConfig { 
  4.    ... 
  5.    ndk { 
  6.        abiFilters "armeabi-v7a", "x86" 
  7.    } 
  8.  
  9.    packagingOptions { 
  10.        exclude "lib/arm64-v8abrealm-jni.so" 
  11.    } 
  12. }   

Genymotion模拟器运行显示没有连接到developement server如下图

先检查是否连接到网络

点击模拟器中Menu菜单弹出下面图片,点击Dev Settings

4.点击Debugging 下面的Debug Server host & port for device填写地址和端口

作者:天空oo7

来源:51CTO

时间: 2024-10-02 16:44:31

史上最详细的Android原生APP中添加ReactNative进行混合开发教程的相关文章

电脑怎么重装系统 2016史上最详细的系统重装

  电脑怎么重装系统 2016史上最详细的系统重装 1.为什么有的电脑无法安装Windows 7 有的朋友新买电脑发现是Window 10系统,但由于使用习惯或者工作原因需要更换成Windows 7系统,却总是安装失败,很有可能是你的电脑硬盘格式是GPT格式的.首先我们来了解一下GPT与MBR的概念: 由于磁盘容量越来越大,传统的MBR分区表(主引导记录)已经不能满足大容量磁盘的需求.传统的MBR分区表只能识别磁盘前面的2.2TB左右的空间,对于后面的多余空间只能浪费掉了,而对于单盘4TB的磁盘

史上最详细的CocoaPods安装教程(图文)_IOS

虽然网上关于CocoaPods安装教程多不胜数,但是我在安装的过程中还是出现了很多错误,所以大家可以照下来步骤装一下,我相信会很好用. 前言 在iOS项目中使用第三方类库可以说是非常常见的事,但是要正确地配置他们有时候是非常繁琐的事情,幸运的是CocoaPods是一个很好的解决方案. 什么是CocoaPods CocoaPods是OS X和iOS下的一个第三类库管理工具,通过CocoaPods工具我们可以为项目添加被称为"Pods"的依赖库(这些类库必须是CocoaPods本身所支持的

Android实现EditText中添加和删除bitmap的方法

本文实例讲述了Android实现EditText中添加和删除bitmap的方法.分享给大家供大家参考,具体如下: SpannableString mSpan1 = new SpannableString("1"); /* * this is add bitmap on edit text */ private void displayBitmapOnText(Bitmap thumbnailBitmap) { if(thumbnailBitmap == null) return; in

史上最详细的Toolbar开发讲解,此篇必读!

Toolbar的简介 Toolbar 是 android 5.0 引入的一个新控件,Toolbar出现之前,我们很多时候都是使用ActionBar以及ActionActivity实现顶部导航栏的,因此Toolbar可以理解为是ActionBar的升级版.Toolbar大大扩展了ActionBar,使用更灵活,不像ActionBar那么固定,Toolbar更像是一般的View元素,可以被放置在view树体系的任意位置,可以应用动画,可以跟着scrollView滚动,可以与布局中的其他view交互.

GitHub上史上最全的Android开源项目分类汇总

今天在看博客的时候,无意中发现了 @Trinea在GitHub上的一个项目 Android开源项目分类汇总,由于类容太多了,我没有一个个完整地看完,但是里面介绍的开源项目都非常有参考价值,包括很炫的界面特效设计.个性化控件.工具库.优秀的Android开源项目.开发测试工具.优秀个人和团体等.可以这样说,每一位Andorid开发人员都能从中找到一个或多个适用自己项目的解决方案,消化吸收并加以利用,可以为自己的APP增色不少.文章最后还列出了部分国外著名Android开发者的信息,包括GitHub

手把手教你从头开始搭建友善之臂ARM-tiny4412开发环境(史上最详细!!)

创建一个ARM目录 mkdir   /disk/A9  -p 接下来你需要准备以下的东西 1.arm-linux-gcc-4.5.1     交叉编译器 2.linux-3.5-tiny4412      内核 3.rootfs_qtopia_qt4-20140124.tar.gz    QT文件系统 (做好的) 4.busybox-1.22.1.tar.bz2  文件系统原码  busybox 5.uboot_tiny4412-20130729.tgz   uboot 6.arm-qte-4.

史上最详细的vsftpd配置文件详解_FTP服务器

vsftpd作为一个主打安全的FTP服务器,有很多的选项设置.下面介绍了vsftpd的配置文件列表,而所有的配置都是基于vsftpd.conf这个配置文件的.本文将提供完整的vsftpd.conf的中文说明.学习本文的内容将有助于你初步了解vsftpd的配置文件,但针对具体情况还需要制定具体的配置方法. vsftpd的配置文件 /etc/vsftpd/vsftpd.conf 主配置文件 /usr/sbin/vsftpd Vsftpd的主程序 /etc/rc.d/init.d/vsftpd 启动脚

Android实现App中导航Tab栏悬浮的功能_Android

首先是"饿了么"导航Tab栏悬浮的效果图. 大家可以看到上图中的"分类"."排序"."筛选"会悬浮在app的顶部,状态随着ScrollView(也可能不是ScrollView,在这里姑且把这滑动的UI控件当作ScrollView吧)的滚动而变化.像这种导航Tab栏悬浮的作用相信大家都能体会到,Tab栏不会随着ScrollView等的滚动而被滑出屏幕外,增加了与用户之间的交互性和方便性. 看到上面的效果,相信大家都跃跃欲试了,那

Android App中自定义View视图的实例教程_Android

一.基础很多的Android入门程序猿来说对于Android自定义View,可能都是比较恐惧的,但是这又是高手进阶的必经之路,所有准备在自定义View上面花一些功夫,多写一些文章.先总结下自定义View的步骤: 1.自定义View的属性 2.在View的构造方法中获得我们自定义的属性 3.重写onMesure 4.重写onDraw 我把3用[]标出了,所以说3不一定是必须的,当然了大部分情况下还是需要重写的. 1.自定义View的属性,首先在res/values/  下建立一个attrs.xml