React Native调用Android的原生功能

React Native 通过 JavaScript 接口与原生代码通信,这是通过名为 Bridge 的机制实现的。Bridge 负责在 JavaScript 和原生端之间建立通信桥梁。

以下是调用 Android 原生功能的基本步骤:

在 JavaScript 中,使用 React Native 提供的模块创建一个接口。

这个接口会被编译成 Java 或 Kotlin 代码,并在 Android 项目的 android/app/src/main/java/<你的包名>/ 目录下的相应 Module 中实现。

实现原生功能的具体代码。

通过 Bridge 将原生功能暴露给 JavaScript。

例如,如果你想要调用 Android 的 Toast 功能,你可以创建一个名为 ToastExample 的模块:

java 复制代码
// ToastExample.java

package com.yourpackage;

import android.widget.Toast;
import android.content.Context;

import com.facebook.react.bridge.ReactApplicationContext;
import com.facebook.react.bridge.ReactContextBaseJavaModule;
import com.facebook.react.bridge.ReactMethod;
import com.facebook.react.module.annotations.ReactModule;

@ReactModule(name = ToastExampleModule)
public class ToastExample extends ReactContextBaseJavaModule {

    ToastExample(ReactApplicationContext context) {
        super(context);
    }

    @Override
    public String getName() {
        return "ToastExample";
    }

    @ReactMethod
    public void show(String message, int duration) {
        Toast.makeText(getReactApplicationContext(), message, duration).show();
    }
}

然后在 JavaScript 中这样使用:

javascript 复制代码
import { NativeModules } from 'react-native';

NativeModules.ToastExample.show('Hello, World!', NativeModules.ToastExample.LENGTH_LONG);

这个例子中,我们创建了一个名为 ToastExample 的模块,并在其中定义了一个 show 方法,该方法通过调用 Android 的 Toast 功能来显示一条消息。然后在 JavaScript 中,我们通过 NativeModules.ToastExample.show 调用这个方法。

相关推荐
NE_STOP7 分钟前
Redis--SDS字符串与集合的底层实现原理
java
直奔標竿11 分钟前
Java开发者AI转型第二十二课!Spring AI 个人知识库实战(一)——架构搭建与核心契约落地
java·人工智能·后端·spring·架构
身如柳絮随风扬13 分钟前
深入理解Java IO与NIO的区别:从BIO到NIO的演进
java·nio
A-Jie-Y36 分钟前
JAVA设计模式-抽象工厂模式
java·设计模式
@insist1231 小时前
信息安全工程师-密码学专题(下):构建可信网络空间的核心机制
java·大数据·密码学·软考·信息安全工程师·软件水平考试
TO_ZRG1 小时前
Android WorkManager 完全入门指南
android
摇滚侠1 小时前
Java 零基础全套视频教程,面向对象(高级),笔记 105-120
java·开发语言·笔记
叶落阁主1 小时前
Spring Boot 4 实战:Jackson 2.x 升级到 3.x 踩坑全记录
java·后端·架构
布吉岛的石头1 小时前
Java 中高级面试:JVM 内存模型 + GC 算法高频题总结
java·jvm·面试
2301_792674861 小时前
java学习(day32)
java