其他分享
首页 > 其他分享> > android – 使用expo工具包在native native中加载自定义本机组件

android – 使用expo工具包在native native中加载自定义本机组件

作者:互联网

我试图加载自定义Android WebView,以便能够使用html文件输入上传文件(默认情况下,Android webview不能使用输入文件). Im using this code,唯一的区别是我使用expo工具包,所以我的MainApplication.java是不同的(默认情况下继承自另一个类):

public class MainApplication extends MultiDexApplication {

    // Needed for `react-native link`
    public List<ReactPackage> getPackages() {
      return Arrays.<ReactPackage>asList(
        new MainReactPackage(),
        new CustomWebViewPackage()
    );
  }

  @Override
  public void onCreate() {
      super.onCreate();
      SoLoader.init(this, /* native exopackage */ false);
  }
}

基本上git代码所做的是覆盖默认的反应本机webview以使其在Android中使用CustomWebView.java,使用requireNativeComponent和此代码(this is on CustomWebView.android.js):

var RCTWebView = requireNativeComponent('CustomWebView', WebView, {
nativeOnly: {
    messagingEnabled: PropTypes.bool,
},

});

但是当我使用exp start运行应用程序并导航到具有CustomWebView的屏幕时,我收到此错误:

enter image description here

总结问题是React Native没有读取我的自定义本机组件.有人能帮助我吗?

解决方法:

默认情况下,Expo不支持任何自定义本机模块.这是因为它们只有一个perbuilt二进制文件,它们只加载你编写的JS包.因此,您使用Expo编写的任何代码都只能是纯Javascript.
但是,Expo文档确实说您可以在分离后添加自定义本机模块.
更多信息:

https://docs.expo.io/versions/latest/guides/detach.html#should-i-detach

https://docs.expo.io/versions/latest/introduction/faq.html#what-is-the-difference-between-expo-and-react-native

https://github.com/expo/expo/issues/56

标签:expo,android,reactjs,react-native,react-native-android
来源: https://codeday.me/bug/20191007/1868982.html