Android 使用DeviceEventEmitter 向 React Native 傳值


定義OpenNativeModule 類,實現sendEventToRn靜態方法。

public class OpenNativeModule extends ReactContextBaseJavaModule {
    private ReactContext mReactContext;
    private static ReactContext myContext;

    public OpenNativeModule(ReactApplicationContext context) {
        super(context);
        this.mReactContext = context;
        this.myContext = context;
    }

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

    public static void sendEventToRn(String eventName, @Nullable WritableMap paramss)
    {

        myContext
            .getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
            .emit(eventName, paramss);

    }

    @ReactMethod // 提供給RN調用的方法
    public void openNativeVC() {
        Intent intent = new Intent();
        intent.setClass(mReactContext, LoginActivity.class);
        intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        mReactContext.startActivity(intent);
    }
}

Android 原生方法中調用

// WritableMap 對應 JS 中的 Object
WritableMap event = Arguments.createMap();
 //傳遞的參數
event.putString("userRes",content);
OpenNativeModule.sendEventToRn("LoginSuccess", event);

RN監聽

componentDidMount() {
    this.emitListener = DeviceEventEmitter.addListener('LoginSuccess', (e) => {
     // todo
    alert(e.userRes);
    });
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM