700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > Mac android原生工程中潜入react-native混合开发项目搭建

Mac android原生工程中潜入react-native混合开发项目搭建

时间:2022-08-06 08:14:59

相关推荐

Mac android原生工程中潜入react-native混合开发项目搭建

最近公司有意向要用react-native做开发,自己在去年的时候也接触过,不过没有深入探讨,这两天,抽出时间看了看,顺便看了一下文档,做了一个简易的dome,由于我本人用的mac os 系统,Mac os 系统不同与windos 系统,做起来也相对轻松容易:接下来我就言简意赅的阐述集成搭建步骤:

注意事项:在项目集成之前,说明你已经配置好了react-native 的开发环境,如果没有配置好请参照react-native 中文开发网站:/docs/0.47/getting-started.html

准备好开发环境。

1.打开终端,创建一个项目根目录,如/reactNativeProject:

~$ mkdir reactNativeProject

2.在根目录下创建一个/android 目录:

~$ cd reactNativeProject~$ mkdir android

3.打开android studio 在以android 做为android原生项目的根目录创建一个原生的应用:步骤如下:

注意:project location: 的选择路径为刚才创建项目的…/reactNativeProject/android 目录:这样直接下一步,注意选择的最小sdk版本:API 16: Android 4.1 (Jelly Bean),不得低于这个版本,低于就不支持了:

直接next,最后到finsh,创建成功android 项目:

4.接下来,要在项目根目录下创建一个名为package.json的空文本文件,然后填入以下内容:

{"name": "MyReactNativeApp","version": "0.0.1","private": true,"scripts": {"start": "node node_modules/react-native/local-cli/cli.js start"},"dependencies": {"react": "16.0.0-alpha.6","react-native": "0.44.3"}}

具体操作如下:

$ touch package.json$ open package.json

在打开的弹出package.json 文本编译器中复制上面要填写的内容,并保存。

5.接下来我们使用npm(node包管理器,Node package manager)来安装React和React Native模块。 请打开一个终端/命令提示行,进入到项目目录中(即包含有package.json文件的目录),然后运行下列命令来安装:

~$ npm install

安装的结果如下图:

会多出来一个node_modules目录:

5.在原生的应用中 配置maven

android/build.gradle 文件中添加 React Native 依赖:

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

在 android/app/build.gradle 配置依赖库:

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

同步一下sync now。

6.配置权限:

接着,在 android/app/src/main/AndroidManifest.xml 清单文件中声明网络权限:

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

如果需要访问 DevSettingsActivity 界面(即开发者菜单),则还需要在 AndroidManifest.xml 中声明:

<activity android:name="com.facebook.react.devsupport.DevSettingsActivity" />

7.代码集成

在/reactNativeProject 根目录下创建一个index.android.js文件

~$ touch index.android.js

打开index.android.js,复制一下内容:

~$ open index.android.js

'use strict';import React from 'react';import {AppRegistry,StyleSheet,Text,View} from 'react-native';class HelloWorld extends ponent {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);

在android 项目创建一个类ReactActivity.java 代码如下:

package com.example.reactnativedome;import android.content.Intent;import .Uri;import android.os.Build;import android.provider.Settings;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.view.KeyEvent;import android.widget.Toast;import mon.logging.FLog;import com.facebook.react.ReactInstanceManager;import com.facebook.react.ReactRootView;import com.mon.LifecycleState;import com.mon.ReactConstants;import com.facebook.react.devsupport.DoubleTapReloadRecognizer;import com.facebook.react.modules.core.DefaultHardwareBackBtnHandler;import com.facebook.react.shell.MainReactPackage;import static java.security.AccessController.getContext;public class ReactActivity extends AppCompatActivity implements DefaultHardwareBackBtnHandler {public static final int OVERLAY_PERMISSION_REQ_CODE = 1235;private ReactRootView mReactRootView;private ReactInstanceManager mReactInstanceManager;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_react);if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {if (!Settings.canDrawOverlays(this)) {Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION,Uri.parse("package:" + getPackageName()));startActivityForResult(intent, OVERLAY_PERMISSION_REQ_CODE);}}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();// 注意这里的MyReactNativeApp必须对应“index.android.js”中的// “AppRegistry.registerComponent()”的第一个参数mReactRootView.startReactApplication(mReactInstanceManager, "MyReactNativeApp", null);setContentView(mReactRootView);}@Overridepublic void invokeDefaultOnBackPressed() {super.onBackPressed();}@Overrideprotected void onActivityResult(int requestCode, int resultCode, Intent data) {// super.onActivityResult(requestCode, resultCode, data);if (requestCode == OVERLAY_PERMISSION_REQ_CODE) {if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {if (!Settings.canDrawOverlays(this)) {// SYSTEM_ALERT_WINDOW permission not granted...}}}}@Overrideprotected void onPause() {super.onPause();if (mReactInstanceManager != null) {mReactInstanceManager.onHostPause(this);}}@Overrideprotected void onResume() {super.onResume();if (mReactInstanceManager != null) {mReactInstanceManager.onHostResume(this, this);}}@Overrideprotected void onDestroy() {super.onDestroy();if (mReactInstanceManager != null) {mReactInstanceManager.onHostDestroy();}}@Overridepublic void onBackPressed() {if (mReactInstanceManager != null) {mReactInstanceManager.onBackPressed();} else {super.onBackPressed();}}@Overridepublic boolean onKeyUp(int keyCode, KeyEvent event) {if (keyCode == KeyEvent.KEYCODE_MENU && mReactInstanceManager != null) {mReactInstanceManager.showDevOptionsDialog();return true;}return super.onKeyUp(keyCode, event);}}

接着,在 android/app/src/main/AndroidManifest.xml 清单文件中注册:

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

在MainActivity.java 修改代码如下:

package com.example.reactnativedome;import android.content.Intent;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.view.View;public class MainActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);findViewById(R.id.tv_react_native).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View view) {Intent intent=new Intent(MainActivity.this,ReactActivity.class);startActivity(intent);}});}}

在 android studio 中 run 运行安装到手机中:

最后在android studio 中终端 terminal 下输入:

~$ nom start

效果如图:

运行结果如图示:

参考来自:/docs/0.47/integration-with-existing-apps.html#content

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。