本机模块 RNDatePicker 尝试覆盖 RNDatePicker。检查 MainApplication.java 中的 getPackages() 方法

Nav*_*n M 5 android datepicker jsx react-native

我在我的项目中使用了react-native-community/datetimepicker来实现日期选择器,我在iOS中没有任何问题,但在android中我的MainApplication.java中有一些问题,有人帮助我修复错误我已附上我的 MainApplication.java 文件在这里,我已经尝试了所有可能的方法,但未能解决此问题

package com.rndemo;

import android.app.Application;
import com.facebook.react.PackageList;
import com.facebook.react.ReactApplication;
import com.facebook.react.ReactNativeHost;
import com.facebook.react.ReactPackage;
import com.facebook.react.defaults.DefaultNewArchitectureEntryPoint;
import com.facebook.react.defaults.DefaultReactNativeHost;
import com.facebook.soloader.SoLoader;
import java.util.List;

public class MainApplication extends Application implements ReactApplication {

  private final ReactNativeHost mReactNativeHost =
      new DefaultReactNativeHost(this) {
        @Override
        public boolean getUseDeveloperSupport() {
          return BuildConfig.DEBUG;
        }

        @Override
        protected List<ReactPackage> getPackages() {
          @SuppressWarnings("UnnecessaryLocalVariable")
          List<ReactPackage> packages = new PackageList(this).getPackages();
          // packages.add(new RNDatePickerPackage());
          return packages;
        }

        @Override
        protected String getJSMainModuleName() {
          return "index";
        }

        @Override
        protected boolean isNewArchEnabled() {
          return BuildConfig.IS_NEW_ARCHITECTURE_ENABLED;
        }

        @Override
        protected Boolean isHermesEnabled() {
          return BuildConfig.IS_HERMES_ENABLED;
        }
      };

  @Override
  public ReactNativeHost getReactNativeHost() {
    return mReactNativeHost;
  }

  @Override
  public void onCreate() {
    super.onCreate();
    SoLoader.init(this, /* native exopackage */ false);
    if (BuildConfig.IS_NEW_ARCHITECTURE_ENABLED) {
      // If you opted-in for the New Architecture, we load the native entry point for this app.
      DefaultNewArchitectureEntryPoint.load();
    }
    ReactNativeFlipper.initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
  }
}

Run Code Online (Sandbox Code Playgroud)

Wal*_*cke 2

您可以执行以下操作作为临时修复:

\n

转到node_modules/react-native-date-picker/android/src/main/java并打开DatePickerModule.java

\n

您可以在其中添加以下内容:

\n
@Override    \npublic boolean canOverrideExistingModule() {        \n   return true;    \n}  \n
Run Code Online (Sandbox Code Playgroud)\n

它最终应该看起来像这样。

\n

在此输入图像描述

\n

这告诉 Android,如果它在构建过程中看到相同的包,它应该覆盖它,并且您最终将只有 1 个包的引用。

\n

这个问题应该得到解决。尝试重新编译Android。\xe2\x9c\x85

\n

此外,您可以使用patch-packagenode_modules在执行干净操作(即删除并进行全新安装)后保留此更改。

\n

为了扩展这个答案- 该解决方案也可以应用于同一问题,但适用于其他库。重要的部分是将上面的代码添加到扩展的类中ReactContextBaseJavaModule

\n

因此,找到为您的特定库扩展的类ReactContextBaseJavaModule,添加上面的代码,然后重建。

\n

希望这可以帮助!

\n