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 调用这个方法。

相关推荐
2501_915918412 小时前
iOS 26 App 性能测试|性能评测|iOS 26 性能对比:实战策略
android·macos·ios·小程序·uni-app·cocoa·iphone
瓯雅爱分享3 小时前
Java+Vue构建的采购招投标一体化管理系统,集成招标计划、投标审核、在线竞价、中标公示及合同跟踪功能,附完整源码,助力企业实现采购全流程自动化与规范化
java·mysql·vue·软件工程·源代码管理
mit6.8246 小时前
[C# starter-kit] 命令/查询职责分离CQRS | MediatR |
java·数据库·c#
咋吃都不胖lyh6 小时前
SQL-多对多关系
android·mysql·数据分析
诸神缄默不语6 小时前
Maven用户设置文件(settings.xml)配置指南
xml·java·maven
任子菲阳6 小时前
学Java第三十四天-----抽象类和抽象方法
java·开发语言
cyy2986 小时前
android 屏幕适配
android
学Linux的语莫6 小时前
机器学习数据处理
java·算法·机器学习
找不到、了6 小时前
JVM的即时编译JIT的介绍
java·jvm
lvchaoq7 小时前
react 修复403页面无法在首页跳转问题
前端·javascript·react.js