配置ReactNative环境并创建第一个程序

文章目录

一、背景

跨平台开发是日后开发的主流,这里记录学习RN跨平台开发的过程,为日后的工作做准备。

二、环境安装

  1. 安装 Node.js
    访问Node.js官网下载并安装LTS版本。

  2. 查看node版本

    node -v

  3. npm版本

    npm -v

三、创建第一个程序

在终端运行

复制代码
npx react-native@0.72.5 init yourAppName --version 0.72.5

注意: react-native init 命令已经被废弃了,不要在使用这个命令创建项目。

需要在0.72.5版本下创建,否则不能适配鸿蒙环境

四、添加鸿蒙环境依赖

  1. MyRNProject文件夹,找到package.json

  2. 在 scripts 下新增 OpenHarmony 的依赖, 添加依赖后的package.json文件如下所示。

    {
    "name": "AwesomeProject",
    "version": "0.0.1",
    "private": true,
    "scripts": {
    "android": "react-native run-android",
    "ios": "react-native run-ios",
    "lint": "eslint .",
    "start": "react-native start",
    "test": "jest",
    "dev": "react-native bundle-harmony --dev"
    },
    "dependencies": {
    "react": "18.2.0",
    "react-native": "0.72.5"
    },
    "devDependencies": {
    "@babel/core": "^7.20.0",
    "@babel/preset-env": "^7.20.0",
    "@babel/runtime": "^7.20.0",
    "@react-native/eslint-config": "^0.72.2",
    "@react-native/metro-config": "^0.72.11",
    "@tsconfig/react-native": "^3.0.0",
    "@types/react": "^18.0.24",
    "@types/react-test-renderer": "^18.0.0",
    "babel-jest": "^29.2.1",
    "eslint": "^8.19.0",
    "jest": "^29.2.1",
    "metro-react-native-babel-preset": "0.76.8",
    "prettier": "^2.4.1",
    "react-test-renderer": "18.2.0",
    "typescript": "4.8.4"
    },
    "engines": {
    "node": ">=16"
    }
    }

  3. 配置metro.config.js并添加OpenHarmony适配代码 右键选择记事本打开 AwsomeProject\metro.config.js,并添加 OpenHarmony 的适配代码。配置文件的详细介绍,可以参考React Native 中文网。修改完成后的文件内容如下:

    const {mergeConfig, getDefaultConfig} = require('@react-native/metro-config');
    const {createHarmonyMetroConfig} = require('@react-native-oh/react-native-harmony/metro.config');

    /**

    • @type {import("metro-config").ConfigT}
      */
      const config = {
      transformer: {
      getTransformOptions: async () => ({
      transform: {
      experimentalImportSupport: false,
      inlineRequires: true,
      },
      }),
      },
      };

    module.exports = mergeConfig(getDefaultConfig(__dirname), createHarmonyMetroConfig({
    reactNativeHarmonyPackageName: '@react-native-oh/react-native-harmony',
    }), config);

  4. 在 AwesomeProject 目录下运行生成 bundle 文件的命令。

    npm run dev

成功结果

如遇报错:error: unknown command 'bundle-harmony',需要手动在

package.json文件中添加依赖:

复制代码
"memfs":"^4.17.2"

运行成功后,会在your project/harmony/entry/src/main/resources/rawfile 目录下生成 bundle.harmony.js 和 assets 文件夹,assets 用来存放图片(如果 bundle 中不涉及本地图片,则没有 assets 文件夹):

  1. 将bundle 文件和 assets 文件夹粘贴复制到HarmonyOS工程MyRNApplication\entry\src\main\resources\rawfile路径下,在 entry/src/main/ets/pages/Index.ets 中使用。

参考文档:从零开始在HarmonyOS上开发React Native应用

相关推荐
Amumu121382 小时前
Redux介绍(一)
前端·javascript·react.js
麷飞花2 小时前
TypeScript问题
前端·javascript·vscode·typescript·ts
阿湯哥2 小时前
ReAct智能体
前端·react.js·前端框架
放逐者-保持本心,方可放逐2 小时前
electron 中的那些事(很关键)-核心要点补充
前端·javascript·electron
2301_789169542 小时前
ai讲React 18 + Context API 极简教程 解决深层组件调用父组件里其他组件方法
javascript·react.js·ecmascript
lili-felicity2 小时前
React Native for Harmony 直角坐标系:精准定位与手势识别
react native·华为·harmonyos
念念不忘 必有回响2 小时前
vue项目从零开始配置国际化
前端·javascript·vue.js
王同学 学出来2 小时前
React案例实操(一)
react.js
全栈前端老曹2 小时前
【包管理】npm最常见的10大问题故障和解决方案
前端·javascript·rust·npm·node.js·json·最佳实践